摘要:禁止用戶選擇文字在一些應(yīng)用場合,我們不希望用戶能夠選擇文字。在下使用透明效果雖然已經(jīng)停止對的技術(shù)支持了,然而做前端的還得被它惡心一段時間,有些兼容性的問題是我們?nèi)砸鎸Φ?。但是,前端界被虐了這么多年,解決問題的方法總是有的。
禁止用戶選擇文字
在一些應(yīng)用場合,我們不希望用戶能夠選擇文字。比如在拖動交互中,如果用戶能選擇元素內(nèi)部的文字,也就意味著能拖動它們,這樣就會干擾對元素的拖動、影響拖動的效果;再如一些網(wǎng)站也會簡單地通過禁止用戶選擇文字以防止用戶復(fù)制站內(nèi)文字(只能騙騙小白而已,不知道我們都會F12嗎<( ̄︶ ̄)>)。
如何實(shí)現(xiàn)呢?可以采用CSS的user-select屬性,不過這個屬性是非標(biāo)準(zhǔn)的,所以加前綴就少不了了:
.notSelect { -moz-user-select: none; /*火狐*/ -webkit-user-select: none; /*webkit瀏覽器*/ -ms-user-select: none; /*IE10*/ user-select: none; }
在要禁止文字選擇的區(qū)域加上上面這個類即可,要全局禁用就加到body上咯。如果要兼容老舊IE,則應(yīng)該設(shè)置元素的onselectstart屬性,可以使用如下js:
element.onselectstart = function() { return false; };安全地使用insertBefore()方法
Node.insertBefore()方法可不止能用來插入節(jié)點(diǎn)到指定節(jié)點(diǎn)前面,其實(shí)你想添加到哪里都可以。因?yàn)樗牡诙€參數(shù)既可以是參考的兄弟節(jié)點(diǎn),還可以是null,傳入null的效果就是把節(jié)點(diǎn)插入到最后,相當(dāng)于實(shí)現(xiàn)了Node.appendChild()。所以,我們把它當(dāng)成一個添加子節(jié)點(diǎn)的全能方法。
但是如果第二個參數(shù)不是調(diào)用該方法的節(jié)點(diǎn)的一個有效子節(jié)點(diǎn)、也不是null,會有什么問題呢?我們來驗(yàn)證一下:
這里ul.children[3]并不存在,直接訪問的結(jié)果是undefined,但是執(zhí)行上面的代碼卻并沒有錯誤發(fā)生(用的chrome),反而直接把新節(jié)點(diǎn)插入了最后,和第二個參數(shù)直接傳null的效果一樣。看來瀏覽器在實(shí)現(xiàn)insertBefore時是有做了容錯的,如果第二個參數(shù)不是有效的DOM節(jié)點(diǎn)也會將其當(dāng)成null處理。
但是現(xiàn)實(shí)總是殘酷的,指望瀏覽器來給我們處理錯誤并不靠譜,比如上面提到的容錯在IE8以下的瀏覽器是沒有滴,如果你在IE8運(yùn)行上述代碼,直接就給你報(bào)錯了。所以為了你的代碼安全運(yùn)行,一旦你不能保證你要傳給insertBefore的第二個參數(shù)的是一個有效的節(jié)點(diǎn),那就老實(shí)寫成兄弟節(jié)點(diǎn) || null的形式吧,手動消滅出錯的機(jī)會。
在IE8下使用透明效果雖然ms已經(jīng)停止對IE8的技術(shù)支持了,然而做前端的還得被它惡心一段時間,有些兼容性的問題是我們?nèi)砸鎸Φ?。如果你?b>opacity和rgba擼了一個有透明效果的頁面,放到IE8-下一看,乖乖,一點(diǎn)朦朧的美感都沒有了。。。
但是,前端界被IE虐了這么多年,解決問題的方法總是有的。我們可以使用IE獨(dú)有的DX濾鏡來解決透明效果的問題,這里以opacity和在背景使用rgba顏色為例,我們都可以找到替代的方法:
opacity: x ---> filter: progid:DXImageTransform.Microsoft.Alpha(opacity=100*x); background: rgba(0,0,0,x); ---> filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#y000000,endColorstr=#y000000); /* 其中y=255*x(十六進(jìn)制),y后面的六位是十六進(jìn)制顏色 */
這里要注意兩點(diǎn),一是用于背景色透明的方法似乎只能用于塊級元素,對行內(nèi)元素并沒有效果。二是由于IE9同時支持標(biāo)準(zhǔn)的透明和濾鏡,所以上面的代碼在IE9中可能會有沖突,同時為了避免和其他瀏覽器的沖突,上面的代碼最好只用作IE9以下瀏覽器的hack。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/78773.html
摘要:而寫成還可以滿足你獲得回調(diào)函數(shù)返回值的需求。而構(gòu)建函數(shù)表達(dá)式的方法也不止把聲明括起來這種,一些其他的操作符也可以,比如賦值號到目前為止,我們似乎能夠得出結(jié)論函數(shù)聲明后不可直接跟圓括號,而函數(shù)表達(dá)式后面可以。 使用setTimeout替代setInterval setInterval()這個間歇調(diào)用函數(shù)是應(yīng)用得比較廣的,尤其在比較古老的瀏覽器中實(shí)現(xiàn)動畫效果時,往往離不開它。然而這個函數(shù)卻...
閱讀 2146·2023-04-25 18:49
閱讀 1852·2019-08-30 14:02
閱讀 2652·2019-08-29 17:24
閱讀 3333·2019-08-28 18:10
閱讀 2935·2019-08-28 18:03
閱讀 498·2019-08-26 12:01
閱讀 3318·2019-08-26 11:31
閱讀 1438·2019-08-26 10:29