JavaScript允許你即時的改變CSS樣式,這樣就可以將使用者的眼球吸引到你想他們關注的地方上,並且提供較好的互動體驗給力 。
JavaScript修改CSS有4種方法:
修改節點style(內聯樣式);
改變節點class或id;
寫入新的css;
替換頁面中的樣式表。
個人不建議使用後兩種方法,幾乎所有的功能都可以透過前兩種方式實現,而且程式碼更加清晰、易於理解。
後面還會說說如何取得元素的真實樣式和一個表單中的注意事項。
1、修改節點style(內聯樣式)
這種方法權重是最高的,直接寫在節點的style屬性上,他會覆蓋其他方法設定的樣式。使用方法很簡單:
var element = document.getElementById("test"); element.style.display = "none" //让元素隐藏
但是要注意的是,有些CSS樣式名稱是由幾個單字組成的例如font-size、background-image等,他們都是用破折號(-)連接起來的,然而JavaScript中破折號表示“減” ,因此不能作為屬性名稱。我們需要使用「駝峰格式(camelCase)」來書寫屬性名,例如fontSize、backgroundImage。
還要注意的是,很多style都是有單位的,不能只給一個數字。例如fontSize的單位有px、em、%(百分比)等。
這種方法違反了表現和行為分離的原則,一般只適合定義元素經常變化的即時樣式(與行為相關),例如一個可用於拖曳的div,隨著拖拽,他的top、left屬性是不斷變換的,此時就不能用class或其他方式定義了,使用這種方式可以即時修改樣式,並且覆寫其他方式的設定。
2、更改class、id
id和class是設定樣式的“鉤子”,更改之後瀏覽器會自動更新元素的樣式。
更改id的方法和class的類似,但是個人並不建議這樣使用,因為id是用於定位元素的,最好不要用它來定義元素的顯示樣式,並且id也常作為JavaScript的鉤子,可能會引起不必要的錯誤。
在JavaScript中,class是一個保留關鍵字,因此使用className作為存取元素class的屬性,例如:
.redColor{ color: red; } .yellowBack{ background: yellow; } element.className = "redColor";//设置class element.className += " yellowBack";//增加class
但比較鬱悶的是,這個屬性是一個包含元素所有class的字串,所有class以空格分開,這樣在刪除class時就很不方便(增加就好說,之間做個字串連接就可以了,不過記得前面要加個空格~)。
我之前在刪除的時候用了正規表示式,根據class在字串中的不同位置進行刪除(頭部、尾部、中間),不過後來想到了更好的辦法,就是在className屬性頭尾都加上一個空格,那就全部變成中間的方法了,直接進行子字串替換:
//删除class function removeClass(element,classRomove){ var classNames = " "+element.className+" "; classNames = classNames .replace(" "+classRomove+" ", " "); //String.trim(classNames); element.className = classNames; }
一般的樣式修改最好都用這種方法,定義好CSS的樣式,JavaScript只是發出樣式改變的指令,具體的樣式定義還是交給CSS去做。
後兩種方法,既不優雅,也有一定相容性問題,我就不介紹了~
3、取得真實樣式
首先要說清楚的是,透過element.style是不行的,他只能取得內聯樣式,樣式表中的定義無法取得。
既然元素的樣式可以定義在這麼多種地方,那他的真實樣式到底是什麼樣子就不好說了,有什麼辦法能獲取到元素在瀏覽器中顯示的真實樣式呢?
其實微軟和W3C都提供了對應的方法,我們只要進行一下封裝就可以用了:
//获取元素样式 function getRealStyle(element,styleName){ var realStyle = null; if(element.currentStyle){ realStyle = element.currentStyle[styleName];//IE }else if(window.getComputedStyle){ realStyle=window.getComputedStyle(element,null)[styleName];//W3C } return realStyle; }
記得傳入的styleName是用「駝峰格式」的~~
4、表單的顯示與隱藏(不要濫用CSS)
我們經常會見到一些表單的選項是動態添加的,例如你某個表單中選擇了婚姻狀態是“已婚”,那麼就會多一個輸入框讓你輸入配偶的姓名。
如果沒有選擇那當然就要把「配偶」的相關表單都隱藏了,但在這個時候不應當用CSS來解決,即不能用style.display=」none」來隱藏。
因為無論你隱或不隱藏它,輸入框就在那裡,不增不減~ [暈] 直白點說,就是雖然隱藏了,但他還是存在與DOM中,如果此時用戶提交表單,會把這個隱藏的輸入框的內容一起提交,可能會出現一些意想不到的錯誤~
正確的做法是將這段內容放入DOM超空間中,這樣就不會有上面的問題了。
以上所述就是本文的全部內容了,希望大家能夠喜歡。

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Linux新版
SublimeText3 Linux最新版

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),