天天看點

javascript小技巧 超強推薦

事件源對象

event.srcElement.tagName

event.srcElement.type

捕獲釋放

event.srcElement.setCapture();

event.srcElement.releaseCapture();

事件按鍵

event.keyCode

event.shiftKey

event.altKey

event.ctrlKey

事件傳回值

event.returnValue

滑鼠位置

event.x

event.y

窗體活動元素

document.activeElement

綁定事件

document.captureEvents(Event.KEYDOWN);

通路窗體元素

document.all("txt").focus();

document.all("txt").select();

窗體指令

document.execCommand

窗體COOKIE

document.cookie

菜單事件

document.oncontextmenu

建立元素

document.createElement("SPAN");

根據滑鼠獲得元素:

document.elementFromPoint(event.x,event.y).tagName=="TD

document.elementFromPoint(event.x,event.y).appendChild(ms)

窗體圖檔

document.images[索引]

窗體事件綁定

document.οnmοusedοwn=scrollwindow;

元素

document.窗體.elements[索引]

對象綁定事件

document.all.xxx.detachEvent('onclick',a);

插件數目

navigator.plugins

取變量類型

typeof($js_libpath) == "undefined"

下拉框

下拉框.options[索引]

下拉框.options.length

查找對象

document.getElementsByName("r1");

document.getElementById(id);

定時

timer=setInterval('scrollwindow()',delay);

clearInterval(timer);

UNCODE編碼

escape() ,unescape

父對象

obj.parentElement(dhtml)

obj.parentNode(dom)

交換表的行

TableID.moveRow(2,1)

替換CSS

document.all.csss.href = "a.css";

并排顯示

display:inline

隐藏焦點

hidefocus=true

根據寬度換行

style="word-break:break-all"

自動重新整理

<meta HTTP-EQUIV="refresh" CONTENT="8;URL=http://c98.yeah.net">

簡單郵件

<a href="mailto:[email protected]?subject=ccc&body=xxxyyy">

快速轉到位置

obj.scrollIntoView(true)

<a name="first">

<a href="#first" target="_blank" rel="external nofollow" >anchors</a>

網頁傳遞參數

location.search();

可編輯

obj.contenteditable=true

執行菜單指令

obj.execCommand

雙位元組字元

/[^/x00-/xff]/

漢字

/[/u4e00-/u9fa5]/

讓英文字元串超出表格寬度自動換行

word-wrap: break-word; word-break: break-all;

透明背景

<IFRAME src="1.htm" width=300 height=180 allowtransparency></iframe>

獲得style内容

obj.style.cssText

HTML标簽

document.documentElement.innerHTML

第一個style标簽

document.styleSheets[0]

style标簽裡的第一個樣式

document.styleSheets[0].rules[0]

防止點選空連結時,頁面往往重置到頁首端。

<a href="javascript:function()" target="_blank" rel="external nofollow" >word</a>

上一網頁源

asp:

request.servervariables("HTTP_REFERER")

javascript:

document.referrer

釋放記憶體

CollectGarbage();

禁止右鍵

document.oncontextmenu = function() { return false;}

禁止儲存

<noscript><iframe src="*.htm"></iframe></noscript>

禁止選取<body οncοntextmenu="return false" οndragstart="return false" onselectstart ="return false" οnselect="document.selection.empty()" οncοpy="document.selection.empty()" onbeforecopy="return false"οnmοuseup="document.selection.empty()>

禁止粘貼

<input type=text οnpaste="return false">

位址欄圖示

<link rel="Shortcut Icon" href="favicon.ico" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >

favicon.ico 名字最好不變16*16的16色,放虛拟目錄根目錄下

收藏欄圖示

<link rel="Bookmark" href="favicon.ico" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >

檢視源碼

<input type=button value=檢視網頁源代碼 οnclick="window.location = 'view-source:'+ 'http://www.csdn.net/'">

關閉輸入法

<input style="ime-mode:disabled">

自動全選

<input type=text name=text1 value="123" οnfοcus="this.select()">

ENTER鍵可以讓光标移到下一個輸入框

<input οnkeydοwn="if(event.keyCode==13)event.keyCode=9">

文本框的預設值

<input type=text value="123" οnfοcus="alert(this.defaultValue)">

title換行

obj.title = "123 sdfs "

獲得時間所代表的微秒

var n1 = new Date("2004-10-10".replace(/-/g, "//")).getTime()

視窗是否關閉

win.closed

checkbox扁平

<input type=checkbox style="position: absolute; clip:rect(5px 15px 15px 5px)"><br>

擷取選中内容

document.selection.createRange().duplicate().text

自動完成功能

<input type=text autocomplete=on>打開該功能

<input type=text autocomplete=off>關閉該功能

視窗最大化

<body οnlοad="window.resizeTo(window.screen.width - 4,window.screen.height-50);window.moveTo(-4,-4)">

無關閉按鈕IE

window.open("aa.htm", "meizz", "fullscreen=7");

統一編碼/解碼

alert(decodeURIComponent(encodeURIComponent("http://你好.com?as= hehe")))

encodeURIComponent對":"、"/"、";" 和 "?"也編碼

表格行訓示

<tr οnmοuseοver="this.bgColor='#f0f0f0'" οnmοuseοut="this.bgColor='#ffffff'">

各種尺寸

[複制此代碼]CODE:

s += "/r/n網頁可見區域寬:"+ document.body.clientWidth;

s += "/r/n網頁可見區域高:"+ document.body.clientHeight;

s += "/r/n網頁可見區域高:"+ document.body.offsetWeight +" (包括邊線的寬)";

s += "/r/n網頁可見區域高:"+ document.body.offsetHeight +" (包括邊線的寬)";

s += "/r/n網頁正文全文寬:"+ document.body.scrollWidth;

s += "/r/n網頁正文全文高:"+ document.body.scrollHeight;

s += "/r/n網頁被卷去的高:"+ document.body.scrollTop;

s += "/r/n網頁被卷去的左:"+ document.body.scrollLeft;

s += "/r/n網頁正文部分上:"+ window.screenTop;

s += "/r/n網頁正文部分左:"+ window.screenLeft;

s += "/r/n螢幕分辨率的高:"+ window.screen.height;

s += "/r/n螢幕分辨率的寬:"+ window.screen.width;

s += "/r/n螢幕可用工作區高度:"+ window.screen.availHeight;

s += "/r/n螢幕可用工作區寬度:"+ window.screen.availWidth;

[複制此代碼]CODE:

<input type=text οnkeypress="return event.keyCode>=48&&event.keyCode<=57||(this.value.indexOf('.')<0?event.keyCode==46:false)" οnpaste="return !clipboardData.getData('text').match(//D/)" οndragenter="return false">

//特殊用途

[複制此代碼]CODE:

<input type=button value=導入收藏夾 οnclick="window.external.ImportExportFavorites(true,'http://localhost');">

<input type=button value=導出收藏夾 οnclick="window.external.ImportExportFavorites(false,'http://localhost');">

<input type=button value=整理收藏夾 οnclick="window.external.ShowBrowserUI('OrganizeFavorites', null)">

<input type=button value=語言設定 οnclick="window.external.ShowBrowserUI('LanguageDialog', null)">

<input type=button value=加入收藏夾 οnclick="window.external.AddFavorite('http://www.google.com/', 'google')">

<input type=button value=加入到頻道 οnclick="window.external.addChannel('http://www.google.com/')">

<input type=button value=加入到頻道 οnclick="window.external.showBrowserUI('PrivacySettings',null)">

不緩存

[複制此代碼]CODE:

<META HTTP-EQUIV="pragma" CONTENT="no-cache">

<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">

<META HTTP-EQUIV="expires" CONTENT="0">

正則比對

[複制此代碼]CODE:

比對中文字元的 正規表達式: [/u4e00-/u9fa5]

比對雙位元組字元(包括漢字在内):[^/x00-/xff]

比對空行的 正規表達式:/n[/s| ]*/r

比對HTML标記的 正規表達式:/<(.*)>.*<///1>|<(.*) //>/

比對首尾空格的 正規表達式:(^/s*)|(/s*$)(像vbscript那樣的trim函數)

比對Email位址的 正規表達式:/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*

比對網址URL的 正規表達式:http://([/w-]+/.)+[/w-]+(/[/w- ./?%&=]*)?

以下是例子:

利用 正規表達式限制網頁表單裡的文本框輸入内容:

用 正規表達式限制隻能輸入中文:οnkeyup="value=value.replace(/[^/u4E00-/u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/u4E00-/u9FA5]/g,''))"

1.用 正規表達式限制隻能輸入全角字元: οnkeyup="value=value.replace(/[^/uFF00-/uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/uFF00-/uFFFF]/g,''))"

2.用 正規表達式限制隻能輸入數字:οnkeyup="value=value.replace(/[^/d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))"

3.用 正規表達式限制隻能輸入數字和英文:οnkeyup="value=value.replace(/[/W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))"

消除圖像工具欄

[複制此代碼]CODE:

<IMG SRC="mypicture.jpg" HEIGHT="100px" WIDTH="100px" GALLERYIMG="false"> or

<head>

<meta http-equiv="imagetoolbar" content="no">

</head>

繼續閱讀