成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

谷歌瀏覽器: Snippets小程序哪家強(qiáng)?

peixn / 2968人閱讀

摘要:是可以在的源面板中創(chuàng)建和執(zhí)行的小腳本。通過在和屬性的末尾添加來覆蓋所有鏈接和可選腳本標(biāo)記。默認(rèn)情況下,不執(zhí)行處理腳本,應(yīng)將變量更改為以運(yùn)行這些腳本。在一個(gè)不錯(cuò)的表中顯示所有表單元素及其值和類型。使用和分組來組織信息。

Snippets是可以在Chrome DevTools的“源”面板中創(chuàng)建和執(zhí)行的小腳本。 您可以從任何頁面訪問和運(yùn)行它們。 當(dāng)您運(yùn)行代碼段時(shí),它會從當(dāng)前打開的頁面的上下文執(zhí)行。
顯示所有元素的邊框,看頁面布局非常方便

[].forEach.call($$("*"),function(a){
  a.style.outline="1px solid #"+(~~(Math.random()*(1<<24))).toString(16)
});
allcolors.js
從頁面上的元素中使用的計(jì)算樣式打印所有顏色。 使用樣式化的console.log調(diào)用來可視化每種顏色。

// allcolors.js
// https://github.com/bgrins/devtools-snippets
// Print out CSS colors used in elements on the page.

(function () {
  // Should include colors from elements that have a border color but have a zero width?
  var includeBorderColorsWithZeroWidth = false;

  var allColors = {};
  var props = ["background-color", "color", "border-top-color", "border-right-color", "border-bottom-color", "border-left-color"];
  var skipColors = {
    "rgb(0, 0, 0)": 1,
    "rgba(0, 0, 0, 0)": 1,
    "rgb(255, 255, 255)": 1
  };

  [].forEach.call(document.querySelectorAll("*"), function (node) {
    var nodeColors = {};
    props.forEach(function (prop) {
      var color = window.getComputedStyle(node, null).getPropertyValue(prop),
        thisIsABorderProperty = (prop.indexOf("border") != -1),
        notBorderZero = thisIsABorderProperty ? window.getComputedStyle(node, null).getPropertyValue(prop.replace("color", "width")) !== "0px" : true,
        colorConditionsMet;

      if (includeBorderColorsWithZeroWidth) {
        colorConditionsMet = color && !skipColors[color];
      } else {
        colorConditionsMet = color && !skipColors[color] && notBorderZero;
      }

      if (colorConditionsMet) {
        if (!allColors[color]) {
          allColors[color] = {
            count: 0,
            nodes: []
          };
        }

        if (!nodeColors[color]) {
          allColors[color].count++;
          allColors[color].nodes.push(node);
        }

        nodeColors[color] = true;
      }
    });
  });

  function rgbTextToRgbArray(rgbText) {
    return rgbText.replace(/s/g, "").match(/d+,d+,d+/)[0].split(",").map(function(num) {
      return parseInt(num, 10);
    });
  }

  function componentToHex(c) {
    var hex = c.toString(16);
    return hex.length == 1 ? "0" + hex : hex;
  }

  function rgbToHex(rgbArray) {
    var r = rgbArray[0],
      g = rgbArray[1],
      b = rgbArray[2];
    return "#" + componentToHex(r) + componentToHex(g) + componentToHex(b);
  }

  var allColorsSorted = [];
  for (var i in allColors) {
    var rgbArray = rgbTextToRgbArray(i);
    var hexValue = rgbToHex(rgbArray);

    allColorsSorted.push({
      key: i,
      value: allColors[i],
      hexValue: hexValue
    });
  }

  allColorsSorted = allColorsSorted.sort(function (a, b) {
    return b.value.count - a.value.count;
  });

  var nameStyle = "font-weight:normal;";
  var countStyle = "font-weight:bold;";
  function colorStyle(color) {
    return "background:" + color + ";color:" + color + ";border:1px solid #333;";
  };

  console.group("Total colors used in elements on the page: " + window.location.href + " are " + allColorsSorted.length);
  allColorsSorted.forEach(function (c) {
    console.groupCollapsed("%c    %c " + c.key + " " + c.hexValue + " %c(" + c.value.count + " times)",
      colorStyle(c.key), nameStyle, countStyle);
    c.value.nodes.forEach(function (node) {
      console.log(node);
    });
    console.groupEnd();
  });
  console.groupEnd("All colors used in elements on the page");

})();
cachebuster.js
通過在href和src屬性的末尾添加Date.now()來覆蓋所有鏈接和(可選)腳本標(biāo)記。 默認(rèn)情況下,不執(zhí)行處理腳本,應(yīng)將變量process_scripts更改為true以運(yùn)行這些腳本。

//Cache Buster
(function (){
  var rep = /.*?.*/,
      links = document.getElementsByTagName("link"),
      scripts = document.getElementsByTagName("script"),
      process_scripts = false;
  for (var i=0;i
console-save.js
從控制臺將對象保存為.json文件的簡單方法包括一個(gè)chrome擴(kuò)展和一個(gè)純文本。
console.save(data, [filename])

(function(console){

    console.save = function(data, filename){

        if(!data) {
            console.error("Console.save: No data")
            return;
        }

        if(!filename) filename = "console.json"

        if(typeof data === "object"){
            data = JSON.stringify(data, undefined, 4)
        }

        var blob = new Blob([data], {type: "text/json"}),
            e    = document.createEvent("MouseEvents"),
            a    = document.createElement("a")

        a.download = filename
        a.href = window.URL.createObjectURL(blob)
        a.dataset.downloadurl =  ["text/json", a.download, a.href].join(":")
        e.initMouseEvent("click", true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null)
        a.dispatchEvent(e)
    }
})(console)
formcontrols.js
在一個(gè)不錯(cuò)的表中顯示所有html表單元素及其值和類型。 在頁面上為每個(gè)表單添加一個(gè)新表

// formcontrols.js
// https://github.com/bgrins/devtools-snippets
// Print out forms and their controls

(function() {

  var forms = document.querySelectorAll("form");

  for (var i = 0, len = forms.length; i < len; i++) {
    var tab = [ ];

    console.group("HTMLForm quot;" + forms[i].name + "quot;: " + forms[i].action);
    console.log("Element:", forms[i], "
Name:    "+forms[i].name+"
Method:  "+forms[i].method.toUpperCase()+"
Action:  "+forms[i].action || "null");

    ["input", "textarea", "select"].forEach(function (control) {
      [].forEach.call(forms[i].querySelectorAll(control), function (node) {
        tab.push({
          "Element": node,
          "Type": node.type,
          "Name": node.name,
          "Value": node.value,
          "Pretty Value": (isNaN(node.value) || node.value === "" ? node.value : parseFloat(node.value))
        });
      });
    });

    console.table(tab);
    console.groupEnd();
  }
})();
log-globals.js
打印全局變量

*
    log-globals
    by Sindre Sorhus
    https://github.com/sindresorhus/log-globals
    MIT License
*/
(function () {
    "use strict";

    function getIframe() {
        var el = document.createElement("iframe");
        el.style.display = "none";
        document.body.appendChild(el);
        var win = el.contentWindow;
        document.body.removeChild(el);
        return win;
    }

    function detectGlobals() {
        var iframe = getIframe();
        var ret = Object.create(null);

        for (var prop in window) {
            if (!(prop in iframe)) {
                ret[prop] = window[prop];
            }
        }

        return ret;
    }

    console.log(detectGlobals());
})();
performance.js
打印有關(guān)window.performance對象的信息。 使用console.table和分組來組織信息。

// performance.js
// https://github.com/bgrins/devtools-snippets
// Print out window.performance information.
// https://developer.mozilla.org/en-US/docs/Navigation_timing

(function () {

  var t = window.performance.timing;
  var lt = window.chrome && window.chrome.loadTimes && window.chrome.loadTimes();
  var timings = [];

  timings.push({
    label: "Time Until Page Loaded",
    time: t.loadEventEnd - t.navigationStart + "ms"
  });
  timings.push({
    label: "Time Until DOMContentLoaded",
    time: t.domContentLoadedEventEnd - t.navigationStart + "ms"
  });
  timings.push({
    label: "Total Response Time",
    time: t.responseEnd - t.requestStart + "ms"
  });
  timings.push({
    label: "Connection",
    time: t.connectEnd - t.connectStart + "ms"
  });
  timings.push({
    label: "Response",
    time: t.responseEnd - t.responseStart + "ms"
  });
  timings.push({
    label: "Domain Lookup",
    time: t.domainLookupEnd - t.domainLookupStart + "ms"
  });
  timings.push({
    label: "Load Event",
    time: t.loadEventEnd - t.loadEventStart + "ms"
  });
  timings.push({
    label: "Unload Event",
    time: t.unloadEventEnd - t.unloadEventStart + "ms"
  });
  timings.push({
    label: "DOMContentLoaded Event",
    time: t.domContentLoadedEventEnd - t.domContentLoadedEventStart + "ms"
  });
  if(lt) {
    if(lt.wasNpnNegotiated) {
      timings.push({
        label: "NPN negotiation protocol",
        time: lt.npnNegotiatedProtocol
      });
    }
    timings.push({
      label: "Connection Info",
      time: lt.connectionInfo
    });
    timings.push({
      label: "First paint after Document load",
      time: Math.ceil(lt.firstPaintTime - lt.finishDocumentLoadTime) + "ms"
    });
  }

  var navigation = window.performance.navigation;
  var navigationTypes = { };
  navigationTypes[navigation.TYPE_NAVIGATENEXT || 0] = "Navigation started by clicking on a link, or entering the URL in the user agent"s address bar, or form submission.",
  navigationTypes[navigation.TYPE_RELOAD] = "Navigation through the reload operation or the location.reload() method.",
  navigationTypes[navigation.TYPE_BACK_FORWARD] = "Navigation through a history traversal operation.",
  navigationTypes[navigation.TYPE_UNDEFINED] = "Navigation type is undefined.",

  console.group("window.performance");

  console.log(window.performance);

  console.group("Navigation Information");
  console.log(navigationTypes[navigation.type]);
  console.log("Number of redirects that have taken place: ", navigation.redirectCount)
  console.groupEnd("Navigation Information");

  console.group("Timing");
  console.log(window.performance.timing);
  console.table(timings, ["label", "time"]);
  console.groupEnd("Timing");

  console.groupEnd("window.performance");

})();
更多有意思的:http://bgrins.github.io/devto...

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/50434.html

相關(guān)文章

  • 谷歌覽器Snippets程序哪家強(qiáng)?

    摘要:是可以在的源面板中創(chuàng)建和執(zhí)行的小腳本。通過在和屬性的末尾添加來覆蓋所有鏈接和可選腳本標(biāo)記。默認(rèn)情況下,不執(zhí)行處理腳本,應(yīng)將變量更改為以運(yùn)行這些腳本。在一個(gè)不錯(cuò)的表中顯示所有表單元素及其值和類型。使用和分組來組織信息。 Snippets是可以在Chrome DevTools的源面板中創(chuàng)建和執(zhí)行的小腳本。 您可以從任何頁面訪問和運(yùn)行它們。 當(dāng)您運(yùn)行代碼段時(shí),它會從當(dāng)前打開的頁面的上下文執(zhí)行...

    sumory 評論0 收藏0
  • 谷歌覽器Snippets程序哪家強(qiáng)?

    摘要:是可以在的源面板中創(chuàng)建和執(zhí)行的小腳本。通過在和屬性的末尾添加來覆蓋所有鏈接和可選腳本標(biāo)記。默認(rèn)情況下,不執(zhí)行處理腳本,應(yīng)將變量更改為以運(yùn)行這些腳本。在一個(gè)不錯(cuò)的表中顯示所有表單元素及其值和類型。使用和分組來組織信息。 Snippets是可以在Chrome DevTools的源面板中創(chuàng)建和執(zhí)行的小腳本。 您可以從任何頁面訪問和運(yùn)行它們。 當(dāng)您運(yùn)行代碼段時(shí),它會從當(dāng)前打開的頁面的上下文執(zhí)行...

    tianren124 評論0 收藏0
  • 2015云市場,容器技術(shù)哪家強(qiáng)?

    摘要:雖然已經(jīng)成為了云領(lǐng)域的容器技術(shù)之王,但一個(gè)新的挑戰(zhàn)者已經(jīng)出現(xiàn)了。擁有一套集群來連接其他的集群服務(wù),例如以及亞馬遜的容器服務(wù)等。也對有著同樣的關(guān)注,后者是谷歌的開源容器管理器。微軟公司于近期實(shí)施了,這是企業(yè)應(yīng)用容器技術(shù)的一個(gè)共同選擇。 雖然Docker已經(jīng)成為了云領(lǐng)域的容器技術(shù)之王,但一個(gè)新的挑戰(zhàn)者已經(jīng)出現(xiàn)了。專家David Linthicum針對這一競爭進(jìn)行了分析。隨著新的一輪競爭開始,容器...

    frontoldman 評論0 收藏0
  • Google軟件工程師解讀:深度學(xué)習(xí)的activation function哪家強(qiáng)?

    摘要:現(xiàn)為谷歌軟件工程師。盡管存在這兩個(gè)問題,目前仍是最常用的,在搭建人工神經(jīng)網(wǎng)絡(luò)的時(shí)候推薦優(yōu)先嘗試函數(shù)人們?yōu)榱私鉀Q,提出了將的前半段設(shè)為而非。 夏飛,清華大學(xué)計(jì)算機(jī)軟件學(xué)士,卡內(nèi)基梅隆大學(xué)人工智能碩士。現(xiàn)為谷歌軟件工程師。TLDR (or the take-away)優(yōu)先使用ReLU (Rectified Linear Unit) 函數(shù)作為神經(jīng)元的activation function:背景深度...

    frolc 評論0 收藏0
  • 外貿(mào)用wordpress建站怎么樣?wordpress外貿(mào)虛擬主機(jī)推薦

    摘要:外貿(mào)虛擬主機(jī)推薦進(jìn)入官網(wǎng)已經(jīng)將對的熱情轉(zhuǎn)化為您網(wǎng)站最快最簡單的管理平臺。進(jìn)入官網(wǎng)已致力于及其社區(qū)超過年。阿里云虛擬主機(jī)根據(jù)不同配置情況不同成本價(jià)格,有北京杭州深圳香港美國等機(jī)房可以選擇。外貿(mào)用wordpress建站怎么樣?wordpress搭建外貿(mào)網(wǎng)站可以嗎?用wordpress搭建了個(gè)機(jī)加工外貿(mào)網(wǎng)站是可以的,如果你要的建設(shè)的是一個(gè)外貿(mào)網(wǎng)站,并想用這個(gè)網(wǎng)站去做谷歌推廣,那么,我建議大家一定選...

    weizx 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<