一堆 width / height

(引用 http://blog.ericsk.org/archives/776#more-776)

記錄一下,以後可以方便自己查詢。

在寫 JavaScript 時最煩的就是計算畫面或是頁面的大小,但是每家瀏覽器提供的內容都不太一樣,所以我就針對幾個瀏覽器(IE, Firefox, Safari, Opera)共同支援的 attr 來寫個簡單的 cheat sheet:

  • document.body.client{Width, Height}
    用來取得目前瀏覽器視窗內頁面區域的 width, height,也就是不含工具列的部份。
  • document.body.offset{Width, Height}
    IE, Opera, Safari: 瀏覽器可視區域大小(同 clientWidth)。
    FF: body 的大小,若無特別指定,寬會隨著瀏覽器的可視區域更改。
  • document.body.scroll{Width, Height}
    IE: body 的大小,若無特別指定,寬會隨著瀏覽器的可視區域更改。
    FF, Opera, Safari: 若可視區域 小於 body 大小,則是 body 大小,否則是可視區域大小。
  • document.documentElement.client{Width, Height}
    IE: (0, 0)
    FF, Opera, : body 的大小。
    Safari: 可視區域大小。
  • document.documentElement.offset{Width, Height}
    IE, Safari: 可視區域大小。
    FF, Opera: body 大小。
  • document.documentElement.scroll{Width, Height}
    IE: 可視區域大小。
    FF, Opera, Safari: 同 document.body.scroll{Width, Height}

看起來,大家都自己 implement 得很開心嘛…完全找不到規則 Orz

javascript正則表達式中用於replace

正則表達式我經常用,但是用的都是最基礎的,基本上都是用於驗證一個字符串的合理性。例如:

var m="12345″;

var n=/^\d+$/;

if(n.test(m)) alert(‘ok’);

今天看了一個關於replace方法中用正則的例子,很有價值,可以輕鬆的實現諸如lenb和trim方法。

我想總結的不是這個,而是在replace中模式與$的替換,例如:

var m=eval(“/(northsnow)+/g");

var n="i am northsnow,I come from Jilin";

var t=n.replace(m,"<b>$1</b>");

alert(n);

則 得到:i am <b>northsnow</b>,I come from Jilin";

括號裡面的模式匹配的結果會被提取出來放到$變量中,$1存儲第一個模式的匹配,$2存儲第二個模式的匹配,以此類推。

例如:

var m="northsnow is a good man";

var n=m.replace(/(\s)([a-z]+)/g,"$1″)

得結果:northsnow

var n=m.replace(/(\s)([a-z]+)/g,"$2″)

得結果:northsnowisagoodman

另外,還有一個\num可以用,這裡邊的num是一個整數,表示將第num個模式拿過來放到這裡。

如果(.)\1表示連續重複的兩個字符。

如果(.)\d*\1 表示有兩個相同的字符,中間夾了n個數字,n>=0

具體就不舉例子了。只要掌握了技巧,那麼就靠實踐來積累經驗了。