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

資訊專欄INFORMATION COLUMN

javascript記錄

Alfred / 717人閱讀

記錄錯誤日志
window.onerror = function(message, url, lineNumber,columnNo,error) {
    var data = {
        "message":message,
        "url":url,
        "error":error.stack
    };
    $.ajax({
        url:"/error/capture",
        type:"post",
        data:data,
        success:function(){
 
        }
    });
    return true;
};
javascript隨機(jī)數(shù)生成算法
function rnd( seed ){
    seed = ( seed * 9301 + 49297 ) % 233280; //為何使用這三個數(shù)?
    return seed / ( 233280.0 );
};

function rand(number){
    today = new Date(); 
    seed = today.getTime();
    return Math.ceil( rnd( seed ) * number );
};

myNum=(rand(5)); 

var rand = (function(){
  var seed = (new Date()).getTime()
  function r(){
    seed = (seed*9301+49297)%233280
    return seed/(233280.0)
  }
  return function(number){
    return Math.ceil(r()*number)
  }
})()

rand = (function(){
  var today = new Date(); 
  var seed = today.getTime();
  function rnd(){
    seed = ( seed * 9301 + 49297 ) % 233280;
    return seed / ( 233280.0 );
  };
  return function rand(number){
    // return Math.ceil(rnd(seed) * number);
    return Math.ceil(rnd() * number);
  };
})();
myNum = (rand(5));
JavaScript 中,如何求出兩個數(shù)組的交集和差集
_.intersection([1, 2, 3], [101, 2, 1, 10], [2, 1]);
=> [1, 2]
_.difference([1, 2, 3, 4, 5], [5, 2, 10]);
=> [1, 3, 4]
let a = new Set([1, 2, 3]);
let b = new Set([3, 5, 2]); 

// 并集
let unionSet = new Set([...a, ...b]);
//[1,2,3,5]

// 交集
let intersectionSet = new Set([...a].filter(x => b.has(x)));
// [2,3]

// ab差集
let differenceABSet = new Set([...a].filter(x => !b.has(x)));
// [1]

再把Set轉(zhuǎn)換為數(shù)組即可.
let arr = Array.from(set);
// 或 let arr = [...set];


相同的

a.filter(function(v){ return b.indexOf(v) > -1 })
不同的
a.filter(function(v){ return !(b.indexOf(v) > -1) }).concat(b.filter(function(v){ return !(a.indexOf(v) > -1)}))
獲取某個DOM元素綁定的事件
getEventListeners($("selector")) 方法以數(shù)組對象的格式返回某個元素綁定的所有事件
getEventListeners($("#firstName")).click[0].listener 會返回ID為 firstName 元素綁定的click事件

inspect($("selector")) 會檢查所有匹配選擇器的DOM元素,并返回所有選擇器選擇的DOM對象。例如inspect($("#firstName")) 選擇所有ID是 firstName 的元素,inspect($("a")[3]) 檢查并返回頁面上第四個 p元素。
$0, $1, $2等等會返回你最近檢查過的幾個元素,例如 $0 會返回你最后檢查的元素,$1 則返回倒數(shù)第二個

img onerror事件觸發(fā)
$("img").each(function() {
    if (!this.complete || typeof this.naturalWidth == "undefined" || this.naturalWidth == 0) {
        this.src = "default.png";
    }
});
禁止瀏覽器記住密碼

在input[type=’password’]的前面加上一個隱藏的密碼框即可,且要求是:不能添加id和name屬性

通過 js 修改微信瀏覽器的title
var $body = $("body");
document.title = ‘title’
// hack在微信等webview中無法修改document.title的情況
var $iframe = $("").on("load", function() {
setTimeout(function() {
$iframe.off("load").remove()
}, 0)
}).appendTo($body)
圖片的預(yù)加載
function imgLoad(src){
    var img = new Image();
    if(img.complete){ //從緩存里面取
        callback();
    }else{
        img.onload = function(){ //實際加載完成
            callback();
        }
    }
    img.src = src;
}
實現(xiàn)類似于add(1)(2)(3)調(diào)用
function add(x){
    var sum = x;
    var tmp = function(y){
        sum = sum + y;
        return tmp;     
    }
    tmp.toString = function(){
        return sum;
    }
    return tmp
}
用代碼來畫個國旗







Your browser does not support the HTML5 canvas tag.




js獲取URL中的參數(shù)
function getQueryString(url, name) {
    var reg = new RegExp("(^|&|?)" + name + "=([^&]*)(&|$)", "i");
    var r = url.substr(1).match(reg);
    if (r != null) return unescape(r[2]); return null;
} 
視頻video標(biāo)簽在移動端的播放總結(jié)
function video_loading( $video ){
        $(".video_loading").show();

        var timer = setInterval(function(){
            var currentTime = $video[0].currentTime; // 檢測當(dāng)前的播放時間

            if( currentTime>0 ){
                $(".video_loading").hide();
                clearInterval( timer );
            }
        }, 100)
    }
    /**
        視頻的播放時間改變時進(jìn)行的操作
        videoid video標(biāo)簽的id
        cur 當(dāng)前播放時間,可以傳入ended參數(shù)
        func 回調(diào)函數(shù)
    */
    videoUpdate : function(videoid, cur, func){
        var myVideo = document.getElementById(videoid);

        if( myVideo ){
            if( typeof cur =="number" ){
                myVideo.addEventListener("timeupdate", function(){
                    if( this.currentTime>=cur ){
                        func();
                        myVideo.removeEventListener("timeupdate", function(){

                        }, false);
                    }
                }, false);
            }else{
                myVideo.addEventListener(cur, function(){
                    func();
                }, false);
            }
        }
    }
    // 第一屏的視頻進(jìn)行到4秒時,顯示透明圖層以提供用戶操作
    tool.videoUpdate( "video1", 4, function(){
        $(".s1 .overlay").show();
    });

    // 第一屏的視頻結(jié)束時,顯示向下滑動提示按鈕
    tool.videoUpdate( "video1", "ended", function(){
        $(".s1 .tip").show();
    });
為博客的文章添加二維碼
$(".bcontent").append("");
$(".bcontent").on("click", ".qrcode a", function(){
    var $tsp = $(this).next();

    if( $tsp.find("canvas").length ){
        if( $tsp.css("display")=="block" ){
            $tsp.hide();
        }else{
            $tsp.show();
        }
    }else{
        if( self.showing ){
            return;
        }
        self.showing = true;
        $tsp.show().html( "正在生成中..." );
        $.ajax({
            url : "jquery.qrcode.min.js",
            dataType : "script",
            type : "get"
        }).done(function(){
            self.showing = false;
            $tsp.html("");
            $tsp.qrcode({
                render : "canvas",
                width : 176,
                height: 176,
                text : window.location.href
            });
        })
    }
})
使用DOM中的a標(biāo)簽解析url
// 創(chuàng)建一個額外的a標(biāo)簽
function parseURL(url) {
    var a =  document.createElement("a");
    a.href = url;
    return {
        source: url,
        protocol: a.protocol.replace(":",""),
        host: a.hostname,
        port: a.port,
        query: a.search,
        params: (function(){
            var ret = {},
                seg = a.search.replace(/^?/,"").split("&"),
                len = seg.length, i = 0, s;
            for (;i
javascript如何添加前置0
function addPreZero(num){
    return ("000000000"+num).slice(-10);
}
html5實現(xiàn)圖片預(yù)覽和查看原圖

var upimg = document.querySelector("#upimg");
upimg.addEventListener("change", function(e){
    var files = this.files;
    if(files.length){
        // 對文件進(jìn)行處理,下面會講解checkFile()會做什么
        checkFile(this.files);
    }
});
// 圖片處理
function checkFile(files){
    var file = files[0];
    var reader = new FileReader();
    // show表示
,用來展示圖片預(yù)覽的 if(!/image/w+/.test(file.type)){ show.innerHTML = "請確保文件為圖像類型"; return false; } // onload是異步操作 reader.onload = function(e){ show.innerHTML = ""; } }
判斷 x 是否是整數(shù)
function isInteger(x) { 
    return parseInt(x, 10) === x; 
}
function add(x, y) {
    return x.toPrecision() + y.toPrecision()
}
console.log(add(0.1,0.2));
function add(num1, num2){
  let r1, r2, m;
  r1 = (""+num1).split(".")[1].length;
  r2 = (""+num2).split(".")[1].length;

  m = Math.pow(10,Math.max(r1,r2));
  return (num1 * m + num2 * m) / m;
}
console.log(add(0.1,0.2));   //0.3
console.log(add(0.15,0.2256)); //0.3756
PhantomJS抓取網(wǎng)頁并將它渲染成圖片
var page = require("webpage").create();
page.settings.userAgent = "WebKit/534.46 Mobile/9A405 Safari/7534.48.3";
page.settings.viewportSize = { width: 400, height: 600 };
page.open("http://m.bbc.co.uk/news/business", function (status) {
    if (status !== "success") {
        console.log("Unable to load BBC!");
        phantom.exit();
    } else {
        window.setTimeout(function () {
            page.clipRect = { left: 0, top: 0, width: 400, height: 600 };
            page.render("bbc-page1.png");
            page.clipRect = { left: 0, top: 600, width: 400, height: 600 };
            page.render("bbc-page2.png");
            phantom.exit();
        }, 2000);
    }
});
復(fù)制與粘貼

Email me at [email protected]

var copyEmailBtn = document.querySelector(".js-emailcopybtn"); copyEmailBtn.addEventListener("click", function(event) { // Select the email link anchor text var emailLink = document.querySelector(".js-emaillink"); var range = document.createRange(); range.selectNode(emailLink); window.getSelection().addRange(range); try { // Now that we"ve selected the anchor text, execute the copy command var successful = document.execCommand("copy"); var msg = successful ? "successful" : "unsuccessful"; console.log("Copy email command was " + msg); } catch(err) { console.log("Oops, unable to copy"); } // Remove the selections - NOTE: Should use // removeRange(range) when it is supported window.getSelection().removeAllRanges(); });
倒計時的JS
 

var time_distance;
var totleTime;
var stop;
function countdownTime(disTime){
    time_distance =disTime;
    totleTime=time_distance;
    showTime();
}
function showTime(){
    time_distance=totleTime;
    var day=0,
    hour=0,
    minute=0,
    second=0;//時間默認(rèn)值
    if(time_distance > 0){
        day = Math.floor(time_distance / (60 * 60 * 24*1000));
        hour = Math.floor(time_distance / (60 * 60*1000)) - (day * 24);
        minute = Math.floor(time_distance / (60*1000)) - (day * 24 * 60) - (hour * 60);
        second = Math.floor(time_distance/1000) - (day * 24 * 60 * 60) - (hour * 60 * 60) - (minute * 60);
    }
    if (hour <= 9) hour = "0" + hour;
    if (minute <= 9) minute = "0" + minute;
    if (second <= 9) second = "0" + second;
    // 顯示時間 
    $("#time_d").text(day+"天");
    $("#time_h").text(hour+"時"); 
    $("#time_m").text(minute+"分"); 
    $("#time_s").text(second+"秒");
    stop=setTimeout("showTime()",1000);
    totleTime=totleTime-1000;
    if(totleTime<1000){
        $("#time_d").text("活動");
        $("#time_h").text("已經(jīng)"); 
        $("#time_m").text("結(jié)束"); 
        $("#time_s").text("。");
        clearTimeout(stop);
        }
    
}
一個數(shù)每隔一秒執(zhí)行加1并打印出來
var count = (function() {
    var timer;
    var i = 0;
    function change(tar) {
        i++;
        console.log(i);
        if (i === tar) {
            clearTimeout(timer);
            return false;
        }
        timer = setTimeout(function() {
            change(tar)
        }, 1000)

    }
    return change;
})()

count(50)
onerror log
"use strict";
function errorHandler( message, source, lineno, colno, error){
    var errorDiv = document.getElementById("error");
    errorDiv.classList.remove("hide");
    console.log("Error happened, message:", message);
    console.log("On source file: ", source);
    console.log("On line - col: ", lineno, "-", colno);
    console.log("Error:", error);
    try {
        var ua = navigator.userAgent;
        console.log("UA: ", ua);
    } catch (e) {
        console.log("Unable to get UA");
    }
}
window.onerror = errorHandler;
javascript copy
"use strict"; function addCopyEventListener(url){ var divs = document.querySelectorAll("div.copyAsText"); for (var index in divs) { if(!divs.hasOwnProperty(index)) { continue; } var div = divs[index]; var input = div.querySelector("input"); var btn = div.querySelector("label"); if (url !== "") { var template = input.getAttribute("data-template"); input.value = template.replace("${url}", url); } void function(btn, input){ btn.addEventListener("click", function(){ if (btn.disabled) { return; } var res = false; try { input.disabled = false; var section = window.getSelection(); section.removeAllRanges(); input.focus(); input.setSelectionRange(0, input.value.length); res = document.execCommand("copy"); input.disabled = true } catch(e) { res = false; } if (res) { var origin = btn.textContent; btn.textContent = "Copied!"; btn.disabled = true; setTimeout(function(){ btn.textContent = origin; btn.disabled = false; }, 2000); } else { window.prompt("Copy to clipboard: Ctrl+C, Enter", input.value); } }); }(btn, input); } } addCopyEventListener(""); //https://github.com/imsobear/blog/issues/31 //只需要對相應(yīng)的元素綁定 mouseenter 的事件,然后響應(yīng) selectText() 這個方法就 ok function selectText (element) { var text = element, range, selection; if (body.createTextRange) { // IE range = body.createTextRange(); range.moveToElementText(text); range.select(); } else if (window.getSelection) { // Others selection = window.getSelection(); range = doc.createRange(); range.selectNodeContents(text); selection.removeAllRanges(); selection.addRange(range); } else { return false; } }
把節(jié)點列表(NodeList)轉(zhuǎn)換為數(shù)組
var elements = document.querySelectorAll("p"); // NodeList
var arrayElements = [].slice.call(elements); // 現(xiàn)在 NodeList 是一個數(shù)組
var arrayElements = Array.from(elements); // 這是另一種轉(zhuǎn)換 NodeList 到 Array  的方法

var array1 = [1,2,3];
var array2 = [4,5,6];
console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6];
JavaScript實現(xiàn)字符串長度截取
 

function cutstr(str, len) {
        var temp;
        var icount = 0;
        var patrn = /[^x00-xff]/;
        var strre = "";
        for (var i = 0; i < str.length; i++) {
            if (icount < len - 1) {
                temp = str.substr(i, 1);
                if (patrn.exec(temp) == null) {
                    icount = icount + 1
                } else {
                    icount = icount + 2
                }
                strre += temp
            } else {
                break
            }
        }
        return strre + "..."
    }
    function $(id) {
        return !id ? null : document.getElementById(id);
    }
  // 用法:如果地址是 test.htm?t1=1&t2=2&t3=3, 那么能取得:GET["t1"], GET["t2"], GET["t3"]
function get_get(){ 
  querystr = window.location.href.split("?")
  if(querystr[1]){
    GETs = querystr[1].split("&")
    GET =new Array()
    for(i=0;i 100) ? "block": "none"
    }
};
backTop("goTop");
    
    
    
    
    
mockjs讓前端開發(fā)獨立于后端
    




rand num
function GetRandomNum(Min,Max)
{   
    var Range = Max - Min;   
    var Rand = Math.random();   
    return(Min + Math.round(Rand * Range));   
}   
var num = GetRandomNum(10,100); 
創(chuàng)建XMLHttpRequest對象
function createXHR(){
    if(typeof XMLHttpRequest != "undefined"){
        return new XMLHttpRequest();
    }else if(typeof ActiveXObject != "undefined"){
        if(typeof arguments.callee.activeXString != "string"){
            var versions = ["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.                       3.0","MSXML2.XMLHttp"],i,len;
            for(i = 0,len=versions.length;i=200 && xhr.status<300) || xhr.status== 304){
            alert(xhr.responseText);
        }else{
            alert("Request was unsuccessful: " + xhr.status);
        }
    }
}
多行文本溢出顯示省略號

var module = document.getElementById("clamp-this-module");
$clamp(module, {clamp: 3});

微信頁面監(jiān)聽搖一搖事件,并伴有音效

鼠標(biāo)向下滾動的時候header會消失
//設(shè)置下css,加個綠色的背景,明顯
$(".sf-header").css({
    background : "#CFC",
    width: "100%"
});

//
$(document).scroll( function(){
    var me = arguments.callee; //匿名函數(shù)可以 通過 arguments.callee 調(diào)用自己
    me.doc = me.doc || $(document); //緩存 $(document);
    me.head = me.head || $(".sf-header");
    me.lastTop = me.lastTop || me.doc.scrollTop();
    if( me.doc.scrollTop() < 20 ||  me.doc.scrollTop() > me.lastTop ){
        //向下 或再 頁面頂部,放在 頭部
        me.head.css({ position : "relative" });
    }else if( me.doc.scrollTop() < me.lastTop  ){
        //向上,懸浮
        me.head.css({ position : "fixed" });
    }
    me.lastTop = me.doc.scrollTop();
});
v2ex 的下一主題
window.location. + (Number(document.location.href.replace(/https://www.v2ex.com/t/(d?)/i, "$1"))+1)
window.location.href.substring(23,29) * 1 + 1
location.href=location.href.split(/[/#]/)[4]*1+1 
location.pathname.substring(3)
判斷一個單詞是否是回文
function checkPalindrom(str) {  
    return str == str.split("").reverse().join("");
}
去掉一組整型數(shù)組重復(fù)的值
let unique = function(arr) {  
  let hashTable = {};
  let data = [];
  for(let i=0,l=arr.length;i
統(tǒng)計一個字符串出現(xiàn)最多的字母
function findMaxDuplicateChar(str) {  
  if(str.length == 1) {
    return str;
  }
  let charObj = {};
  for(let i=0;i= maxValue) {
      maxChar = k;
      maxValue = charObj[k];
    }
  }
  return maxChar;

}
生成斐波那契數(shù)組
function getFibonacci(n) {  
  var fibarr = [];
  var i = 0;
  while(i
閉包

var myObject = {
    foo: "bar",
    func: function() {
        var self = this;
        console.log("outer func:  this.foo = " + this.foo);
        console.log("outer func:  self.foo = " + self.foo);
        (function(test) {
            console.log("inner func:  this.foo = " + test.foo);  //"bar"
            console.log("inner func:  self.foo = " + self.foo);
     }(self));
    }
};
myObject.func();

for(var i = 0; i < 5; i++) {
    setTimeout(function() {
        console.log(i);  // 555555
    }, 1000);
}
for(var i = 0; i < 5; i++) {
    (function(i) {
      setTimeout(function() {
        console.log(i);  //0 , 1 , 2 , 3 , 4 
      }, 1000);
    })(i)
}
function add(num1, num2){
  let r1, r2, m;
  r1 = (""+num1).split(".")[1].length;
  r2 = (""+num2).split(".")[1].length;

  m = Math.pow(10,Math.max(r1,r2));
  return (num1 * m + num2 * m) / m;
}
console.log(add(0.1,0.2));   //0.3
console.log(add(0.15,0.2256)); //0.3756
10 的階乘

console.log((function f(n){return ((n > 1) ? n * f(n-1) : n)})(10));

邏輯與返回第一個是 false 的操作數(shù) 或者 最后一個是 true 的操作數(shù)

如果某個操作數(shù)為 false ,則該操作數(shù)之后的操作數(shù)都不會被計算
console.log(1 && 2 && 0); //0
console.log(1 && 0 && 1); //0
console.log(1 && 2 && 3); //3

邏輯或返回第一個是 true 的操作數(shù) 或者 最后一個是 false 的操作數(shù)
console.log(1 || 2 || 0); //1
console.log(0 || 2 || 1); //2
console.log(0 || 0 || false); //false

如果某個操作數(shù)為 true ,則該操作數(shù)之后的操作數(shù)都不會被計算
如果邏輯與和邏輯或作混合運算,則邏輯與的優(yōu)先級高
if 中,[] 和 {} 都表現(xiàn)為 true

Unicode 編碼轉(zhuǎn)換
function encodeUTF8(str){
    var temp = "",rs = "";
    for( var i=0 , len = str.length; i < len; i++ ){
        temp = str.charCodeAt(i).toString(16);
        rs  += "u"+ new Array(5-temp.length).join("0") + temp;
    }
    return rs;
 }
 function decodeUTF8(str){
    return str.replace(/(u)(w{4}|w{2})/gi, function($0,$1,$2){
        return String.fromCharCode(parseInt($2,16));
    }); 
 } 
encodeUTF8("中文")
"u4e2du6587"
decodeUTF8("u4e2du6587")
"中文"
//https://segmentfault.com/q/1010000000095710
var decToHex = function(str) {
    var res=[];
    for(var i=0;i < str.length;i++)
        res[i]=("00"+str.charCodeAt(i).toString(16)).slice(-4);
    return "u"+res.join("u");
}

var hexToDec = function(str) {
    str=str.replace(//g,"%");
    return unescape(str);
}
var decodeHtmlEntity = function(str) {
  return str.replace(/&#(d+);/g, function(match, dec) {
    return String.fromCharCode(dec);
  });
};
var str = "JavaScript高级程序设计";
console.log(decodeHtmlEntity(str));//JavaScript高級程序設(shè)計
var encodeHtmlEntity = function(str) {
  var buf = [];
  for (var i=str.length-1;i>=0;i--) {
    buf.unshift(["&#", str[i].charCodeAt(), ";"].join(""));
  }
  return buf.join("");
};
var str = "高級程序設(shè)計";
console.log(encodeHtmlEntity(str));//高级程序设计

function u2str(text){ 
     return $("

").html(text).text(); }
數(shù)組反轉(zhuǎn)
var test = [
  [1, 0, 4, 3, 2],
  [0, 4, 3, 2, 1],
  [4, 3, 2, 1, 0],
  [3, 2, 1, 0, 4]
];

test.forEach(arr => console.log(reversal(arr)));

// 反轉(zhuǎn)
function reversal(arr) {
  let len = arr.length;
  // get max
  let max = arr[0];
  let index = 0;
  arr.forEach((v, i) => {
    if (v <= max) return;
    max = v;
    index = i;
  });

  // strat re
  let tmp = arr.reverse().concat(arr, arr);
  let newIndex = len - 1 - index + len;

  return tmp.slice(newIndex - index, newIndex + len - index);
}
var arr = [1, 0, 4, 3, 2];
反轉(zhuǎn)為
var arr = [2, 3, 4, 0, 1];
chrome console

dir($("selector")) 會返回匹配選擇器的DOM元素的所有屬性
獲取某個DOM元素綁定的事件 getEventListeners($("#firstName")).click[0].listener

深拷貝 對象和數(shù)組
var cloneObj = function(obj){
    var str, newobj = obj.constructor === Array ? [] : {};
    if(typeof obj !== "object"){
        return;
    } else if(window.JSON){
        str = JSON.stringify(obj), //系列化對象
        newobj = JSON.parse(str); //還原
    } else {
        for(var i in obj){
            newobj[i] = typeof obj[i] === "object" ? 
            cloneObj(obj[i]) : obj[i]; 
        }
    }
    return newobj;
};
//jQuery.extend第一個參數(shù)可以是布爾值,用來設(shè)置是否深度拷貝的:
jQuery.extend(true, { a : { a : "a" } }, { a : { b : "b" } } );
jQuery.extend( { a : { a : "a" } }, { a : { b : "b" } } );

ajax提交2個相同的鍵值
在form表單中有兩個同name名為"tag",然后在ajax提交的時候直接用serialize進(jìn)行了序列化
 $.post("url", {
  tags: 7,
  tags: 128,
})
或者
var str="tags=7&tags=128";
$.ajax({
    type:"post",
    url:"http://localhost/",//地址自己改
    data:str,
    async:true
});
精度丟失
str = "{"a":1234567890123456789,"b":1234567890123239}";
str = str.substr(1);
str = str.substr(0,str.length-1);
str.split(",");
arr = str.split(",");
obj = {};
arr.forEach(function(el,index){
    var arr1 = el.split(":");
    //obj[arr1[0]]=""+arr1[1];
    obj[arr1[0]]=(Number.isSafeInteger(arr1[1])?arr1[1]:(""+arr1[1]));
});
console.dir(obj);
var str = "{"a":1234567890123456789, "b": 1234567890123456789, "c": 1234567890123456789}";
var json = JSON.parse(str.replace(/: *(d*?) *(,|})/g, (a, b, c) => `:"$"${c}`));
console.log(json);

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

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

相關(guān)文章

  • 由 ECMA 規(guī)范解讀 Javascript 可執(zhí)行上下文概念

    摘要:不包括作為其嵌套函數(shù)的被解析的源代碼。作用域鏈當(dāng)代碼在一個環(huán)境中執(zhí)行時,會創(chuàng)建變量對象的一個作用域鏈。棧結(jié)構(gòu)最頂層的執(zhí)行環(huán)境稱為當(dāng)前運行的執(zhí)行環(huán)境,最底層是全局執(zhí)行環(huán)境。無限制函數(shù)上下文。或者拋出異常退出一個執(zhí)行環(huán)境。 前言 其實規(guī)范這東西不是給人看的,它更多的是給語言實現(xiàn)者提供參考。但是當(dāng)碰到問題找不到答案時,規(guī)范往往能提供想要的答案 。偶爾讀一下能夠帶來很大的啟發(fā)和思考,如果只讀一...

    daryl 評論0 收藏0
  • 深入理解Javascript中的執(zhí)行環(huán)境(Execution Context)和執(zhí)行棧(Execut

    摘要:引擎會執(zhí)行其執(zhí)行環(huán)境位于堆棧頂部的函數(shù)。當(dāng)函數(shù)執(zhí)行完畢時,當(dāng)前執(zhí)行棧會從堆棧中彈出去,并且控件將會到達(dá)其在當(dāng)前堆棧下面的那個執(zhí)行環(huán)境中。當(dāng)完成以后,它的執(zhí)行環(huán)境會會從堆棧中移出,并且控件會到達(dá)全局執(zhí)行環(huán)境。 如果你想成為一個Javascript開發(fā)者,那么你一定要知道Javascript程序的內(nèi)部運行原理。理解執(zhí)行環(huán)境和執(zhí)行棧是非常重要的,其有助于理解其他Javascript的概念,比...

    whidy 評論0 收藏0
  • 深入理解javascript函數(shù)

    摘要:函數(shù)是對象理解函數(shù)是對象,是準(zhǔn)確理解函數(shù)的第一步。在中,函數(shù)對象和其他對象一樣,均被視為一等公民。當(dāng)函數(shù)執(zhí)行完畢,其執(zhí)行環(huán)境從棧中彈出并銷毀。此時的函數(shù)充當(dāng)構(gòu)造器的角色。調(diào)用函數(shù)對象的方法并將結(jié)果賦給。 函數(shù)是javascript中最重要的內(nèi)容,也是其相對其他語言來說在設(shè)計上比較有意思的地方。javascript許多高級特性也或多或少和函數(shù)相關(guān)。本文將以函數(shù)為中心,對函數(shù)的各個關(guān)鍵知識...

    My_Oh_My 評論0 收藏0
  • javascript的執(zhí)行上下文

    摘要:運行執(zhí)行上下文正在使用的執(zhí)行上下文。頂部是正在執(zhí)行的上下文當(dāng)執(zhí)行完畢,它的執(zhí)行上下文自動從棧彈出,控制流程按順序到達(dá)全局執(zhí)行上下文。一旦所有代碼執(zhí)行完畢,引擎從當(dāng)前棧中移除全局執(zhí)行上下文。在全局執(zhí)行上下文中,的值指向全局對象。 https://juejin.im/post/5ba321...https://juejin.im/entry/59986...我只是搬運工,看了他們的文章后深...

    yedf 評論0 收藏0
  • JavaScript 錯誤處理與調(diào)試——“調(diào)試技術(shù)與常見的IE錯誤”的注意要點

    摘要:將消息記錄到控制臺和來說,可通過對象向控制臺中寫入消息。如常見的錯誤操作終止無效字符未找到成員未知運行時錯誤語法錯誤系統(tǒng)無法找到指定資源 將消息記錄到控制臺 console IE8、Firefox、Chrome和Safari來說,可通過console對象向JavaScript控制臺中寫入消息。對象有下列方法: error(message):將錯誤消息記錄到控制臺 info(messa...

    GT 評論0 收藏0
  • javascript閉包不完全探索記錄02:閉包?干嘛使!

    摘要:溫馨提示作者的爬坑記錄,對你等大神完全沒有價值,別在我這浪費生命溫馨提示續(xù)本文將會成為一篇筆記類型的文章,記錄閉包具體的應(yīng)用方式溫馨提示再續(xù)本文存在錯誤,會慢慢改進(jìn)的,請不要把我說的當(dāng)真在上一篇博文閉包不完全探索記錄閉包啥餡的中,對中 溫馨提示:作者的爬坑記錄,對你等大神完全沒有價值,別在我這浪費生命溫馨提示-續(xù):本文(maybe)將會成為一篇筆記類型的文章,記錄閉包具體的應(yīng)用方式溫馨...

    Render 評論0 收藏0

發(fā)表評論

0條評論

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