15個非常實用的JavaScript代碼片段
本文實例為大家分享了非常實用的js片段,供大家參考,具體內容如下
1.如何區(qū)分IE及非IE瀏覽器:
if(!+[1,]){ //IE 11 不支持 alert("這是 IE 瀏覽器"); }else{ alert("這不是 IE 瀏覽器"); }
2.將日期直接轉換為數值:
+new Date();
3.非IE瀏覽器下將類數組對象 “arguments”轉為數組:
Array.prototype.slice.call(arguments);
4.最簡單的選擇運算符||:
var a = 0 || 3; console.log(a); //結果3
如果=后面的第一個值計算結果為布爾值“真”,則 a 的值取第 1 個,否則取第 2 個。
5.單鏈式運算(如 a++ -1):
var a=10; console.log(a++ -1);
先執(zhí)行“a-1”,再執(zhí)行“a=a+1”。
6.有趣的void操作符:
<a href="javascript:void(0)">我是一個死鏈接</a>
void是一種操作符,用來計算一個表達式但不返回值。
7.跳轉至新頁面,并且保證瀏覽器不會再回退:
location.replace("http://www.dbjr.com.cn");
location 的 replace() 方法可以用一個新的文檔替換當前文檔,并且該方法還會覆蓋 History 對象中的記錄。
8.幾秒鐘之后返回上一頁:
<meta http-equiv="refresh" content="3;url=javascript:window.history.go(-1);">
9.在打開的子窗口中刷新父窗口:
window.opener.location.reload();
10.驗證是否為負數的正則表達式:
/^-\d+$/.test(str);
11.用JavaScript打印頁面:
window.print()
12.顯示/隱藏一個DOM元素:
el.style.display = ""; el.style.display = "none"; //el是待操作的DOM元素
DOM元素的顯示/隱藏主要是通過設置元素的樣式display屬性來實現。
13.實現alert()中的文本換行:
alert("p\np")
"\n"代表換行符。
14.實現ECMAScript5中的Object.create()函數:
function clone(proto){ function _clone(){} _clone.prototype = proto; _clone.prototype.constructor = _clone; return new_clone(); //等價于 Object.create(Person); var me = clone(Person);
用原型鏈形式繼承,構造函數重新指向新創(chuàng)建的對象。
15.理解JavaScript中的閉包:
例如,以下代碼會輸出5次,結果都是5,那么如何輸出0、1、2、3、4?
for(var i = 0; i < 5; i++) { setTimeout(function() { console.log(i); }, 1000); }
利用閉包的原理實現,代碼如下:
for(var i = 0; i < 5; i++) { (function(e) { setTimeout(function() { console.log(e); }, 1000); })(i); }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
TypeScript中interface和type的區(qū)別詳解
本文主要介紹了TypeScript中interface和type的區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07微信公眾平臺開發(fā)教程(四) 實例入門:機器人回復(附源碼)
本篇文章主要介紹了微信公眾平臺開發(fā)機器人,可以實現簡單對話和查詢天氣等,有需要的可以了解一下。2016-12-12