JSON

45个JavaScript编程注意事项、技巧大全【站长博客网】(4)

字号+ 作者:H5之家 来源:H5之家 2017-05-10 15:04 我要评论( )

function escapeHTML(text) { var replacements= {"": "", "": "","", "\"": """}; return text.replace(/[nbsp; return replacements[character]; }); } 40、不要在循环内部使用try-catch-finally try-catch-final


  function escapeHTML(text) { 
    var replacements= {"<": "<", ">": ">","&": "&", "\"": """};                     
    return text.replace(/[<>&"]/g, function(character) { 
        return replacements[character]; 
    });
}


40、不要在循环内部使用try-catch-finally

try-catch-finally中catch部分在执行时会将异常赋给一个变量,这个变量会被构建成一个运行时作用域内的新的变量。

切忌:

复制代码 代码如下:


  var object = ['foo', 'bar'], i; 
for (i = 0, len = object.length; i <len; i++) { 
    try { 
        // do something that throws an exception
    } 
    catch (e) {  
        // handle exception 
    }
}


而应该:

复制代码 代码如下:


  var object = ['foo', 'bar'], i; 
try {
    for (i = 0, len = object.length; i <len; i++) { 
        // do something that throws an exception
    }
}
catch (e) {  
    // handle exception 
}

41、使用XMLHttpRequests时注意设置超时
XMLHttpRequests在执行时,当长时间没有响应(如出现网络问题等)时,应该中止掉连接,可以通过setTimeout()来完成这个工作:

复制代码 代码如下:


  var xhr = new XMLHttpRequest ();
xhr.onreadystatechange = function () { 
    if (this.readyState == 4) { 
        clearTimeout(timeout); 
        // do something with response data
    } 

var timeout = setTimeout( function () { 
    xhr.abort(); // call error callback 
}, 60*1000 /* timeout after a minute */ );
xhr.open('GET', url, true); 
xhr.send();


同时需要注意的是,不要同时发起多个XMLHttpRequests请求。

42、处理WebSocket的超时

通常情况下,WebSocket连接创建后,如果30秒内没有任何活动,服务器端会对连接进行超时处理,防火墙也可以对单位周期没有活动的连接进行超时处理。

为了防止这种情况的发生,可以每隔一定时间,往服务器发送一条空的消息。可以通过下面这两个函数来实现这个需求,一个用于使连接保持活动状态,另一个专门用于结束这个状态。

复制代码 代码如下:


  var timerID = 0;
function keepAlive() {
    var timeout = 15000; 
    if (webSocket.readyState == webSocket.OPEN) { 
        webSocket.send(''); 
    } 
    timerId = setTimeout(keepAlive, timeout); 

function cancelKeepAlive() { 
    if (timerId) { 
        cancelTimeout(timerId); 
    } 
}


keepAlive()函数可以放在WebSocket连接的onOpen()方法的最后面,cancelKeepAlive()放在onClose()方法的最末尾。

43、时间注意原始操作符比函数调用快,使用VanillaJS
比如,一般不要这样:

复制代码 代码如下:


  var min = Math.min(a,b);
A.push(v);


可以这样来代替:

复制代码 代码如下:


  var min = a < b ? a : b;
A[A.length] = v;


44、开发时注意代码结构,上线前检查并压缩JavaScript代码
可以使用JSLint或JSMin等工具来检查并压缩代码。

Tag标签:    编程  技  注意事项  

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • javascript eval跟JSON之间的联系

    javascript eval跟JSON之间的联系

    2017-05-08 08:00

  • JSON的学习和使用

    JSON的学习和使用

    2017-05-07 17:02

  • android使用ViewPager实现轮播效果

    android使用ViewPager实现轮播效果

    2017-04-28 12:03

  • 用Newtonsoft将json串转为对象的方法(详解)

    用Newtonsoft将json串转为对象的方法(详解)

    2017-04-24 09:00

网友点评
=