<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>DOM代碼詳述(一)</title>
<script type="text/javascript">
window.onload = function(){
var div1 = document.getElementById("div1");//通過ID獲取唯一的節點;多個同名ID只會取第一個
console.log(div1);
console.log(div1.tagName);//查看節點:①屬性;獲取節點的標簽名
console.log(div1.innerHTML);//②設置或者獲取節點內部的所有HTML代碼
console.log(div1.innerText);//③設置或者獲取節點內部的所有文字
console.log(window.getComputedStyle(div1,null));//查看所有屬性(非IE屬性)
console.log(div1.currentStyle);//查看所有屬性(IE屬性)
}
function getById(){
//取到元素節點的樣式屬性節點
var div1 = document.getElementById("div1").style;//獲取
div1.backgroundColor = "#FF00FF";//行級樣式表權重1000;所有節點屬性,一律駝峰命名法
//取到元素節點
var divDoc = document.getElementById("div1");//獲取
divDoc.innerHTML = "<s>king_land</s>";//重置修改div中的HTML代碼
}
//——————————————分割線——————————————————
function getByName(){//通過Name取到一個數組,包含1到多個節點;
var div = document.getElementsByName("div1");
console.log(div.length);
//使用方式:通過循環,取到每一個節點,循環次數從0開始,<數組.length
for(var n = 0 ;n < div.length ; n++){
div[n].style.backgroundColor = "#FFFF00";
}
//div1.backgroundColor = "#FFFF00";
//div[0].style.backgroundColor = "#FFFF00";//★
}
//——————————————分割線——————————————————
//document.getElementsByTagName();//同Name
function getByTagName(){
var div = document.getElementsByTagName("div");
div[0].style.backgroundColor = "#00FF00";
}
//——————————————分割線——————————————————
//document.getElementsByClassName();//同Name
function getByClass(){
var div = document.getElementsByClassName("div1");
div[0].style.backgroundColor = "#00FFFF";
}
//——————————————分割線——————————————————
function getAttr () {
var img1 = document.getElementById("img1");
alert(img1.getAttribute("src"));
}//查看屬性節點 getAttribute("屬性名");
//——————————————分割線——————————————————
function setAttr () {
var img1 = document.getElementById("img1");
img1.setAttribute("src","../../2-CSS基礎語法/img/bg_flower_multi.gif");
img1.setAttribute("style","width: 100px;height: 100px;");
}//設置屬性節點 getAttribute("屬性名","屬性值");
//——————————————分割線——————————————————
//JS修改樣式總結
//1、.className:為元素設置一個新的class名字 例如:div1.className = "div2";
//2、.style:為元素設置新的樣式 例如:div1.style.background-color = "blue";
//3、.style.cssText:為元素同時修改多個樣式 例如:div1.style.cssText = "width:100px;height:200px;";
</script>
<style type="text/css">
.div1{
height: 100px;
width: 100px;
background-color: #000000;
color: #FFFFFF;
line-height: 100px;
text-align: center;
}
</style>
</head>
<body>
<div id="div1" name="div1" class="div1">
這里是測試區
</div>
<div id="div1" name="div1" class="div1">
這里是測試區
</div>
<div id="div1" name="div1" class="div1">
這里是測試區
</div>
<img src="../../2-CSS基礎語法/img/bg_flower_multi.gif" id="img1"/>
<br />
<button onclick="getById()">通過ID修改divcolor</button>
<br />
<button onclick="getByName()">通過Name修改divcolor</button>
<br />
<button onclick="getByTagName()">通過TagName修改divcolor</button>
<br />
<button onclick="getByClass()">通過ClassName修改divcolor</button>
<br />
<button onclick="getAttr()">取到img的src屬性值</button>
<br />
<button onclick="setAttr()">修改img的src屬性值</button>
</body>
</html>
[獲取層次節點的常用屬性]:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
window.onload = function (){
//獲取層次節點的常用屬性
var ul1 = document.getElementById("ul1");
// var lis = ul1.getElementsByTagName("li"); //只取到ul1中所有li
// var lis = document.getElementsByTagName("li"); //取到頁面中所有的li
console.log(ul1.childNodes);//獲取元素的所有子節點(包含元素節點、文本節點)
console.log(ul1.firstChild);//獲取元素的第一個子節點
console.log(ul1.lastChild);//獲取元素的最后一個子節點
console.log(ul1.ownerDocument);//獲取當前文檔根節點,在html文檔中為document節點
console.log(ul1.parentNode);//獲取當前節點的父節點
console.log(ul1.previousSibling);//獲取當前節點的前一個兄弟節點
console.log(ul1.nextSibling);//獲取當前節點的后一個兄弟節點
//上述屬性均會獲得所有的元素節點和文本節點,如果只需要元素節點,需要使用對應Element屬性,例如:firstChild→firstElementChild
console.log(ul1.attributes);//獲取當前節點的所有屬性節點
}
//——————————————創建並新增節點——————————————————
//方法一:.creatElement("標簽名")創建一個新節點,需要配合setAttribute()方法設置屬性;
//方法二:.appendChild(節點名)在元素的最后追加一個新節點
//方法三:.insertBefore(新節點名,目標節點名):將新節點插入到目標節點之前
//方法四:克隆對象.cloneNode(true/false):需要克隆誰,就用誰去調用克隆節點;傳遞參數可以為true/false,true表示克隆當前節點及子節點;false表示只克隆當前節點,不克隆子節點。
function appendImg(){
//1、創建一個圖片節點
var img = document.createElement("img");
//2、給img節點設置屬性
img.setAttribute("src","../../1-HTML基本標簽/ivicon.png");
//3、將設置好的img節點追加到body最后
document.body.appendChild(img)//.setAttribute("src","../../img/2017-02-25_143342.png");
}
function insertImg(){
//1、創建一個圖片節點
var img = document.createElement("img");
//2、給img節點設置屬性
img.setAttribute("src","../../1-HTML基本標簽/ivicon.png");
//3、在兩個ul之間插入圖片
var ul2 = document.getElementById("ul2");
document.body.insertBefore(img,ul2);
}
var count = 2;
function copyUl(){
//1、取到ul2節點
var ul2 = document.getElementById("ul2");
//2、克隆節點
var ul2Clon = ul2.cloneNode(true);
count ++;
ul2Clon.setAttribute("id","ul"+count)
//3、在原ul2節點之前,插入新克隆節點
document.body.insertBefore(ul2Clon,ul2);
}
//——————————————刪除和替換節點——————————————————
//1、.removeChild(需刪除節點):從父容器中刪除指定節點;
//2、.replaceChild(新節點,被替換節點):用新節點替換被指定節點,如果新節點為頁面中已有節點,會將此節點刪除后替換到指定節點。
function deleteUl1(){
//取到ul1
var ul1 = document.getElementById("ul1");
if (ul1){
//從父容器body中刪除ul1節點
document.body.removeChild(ul1);
}else{
alert("憋刪了,早沒了");
}
}
function ul1ReplaceUl2(){
var div = document.createElement("div");
div.setAttribute("style","width: 100px;height: 100px;background-color: #20B2AA;");
var ul2 = document.getElementById("ul2");
document.body.replaceChild(div,ul2);
}
</script>
<style type="text/css">
ul{
width: 600px;
list-style: none;
padding: 0;
background-color: #20B2AA;
display: flex;
justify-content: space-around;
margin-top: 20px;
}
</style>
</head>
<body>
<ul id="ul1">
<li>第一項</li>
<li>第二項</li>
<li>第三項</li>
<li>第四項</li>
</ul>
<ul id="ul2">
<li>第1項</li>
<li>第2項</li>
<li>第3項</li>
<li>第4項</li>
</ul>
<button onclick="appendImg()">在最后插入一幅圖片</button>
<button onclick="insertImg()">在兩個ul之間插入一幅圖片</button>
<button onclick="copyUl()">copy一個ul2</button>
<br />
<button onclick="deleteUl1()">刪除ul1</button>
<button onclick="ul1ReplaceUl2() ">用ul1替換ul2</button>
</body>
</html>
[創建新增節點]:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>DOM操作表格</title>
<script type="text/javascript">
//表格對象:
//1、rows屬性:返回表格中的所有行,數組;
//2、insertRow(index):在表格的第index+1行,插入一個新行;
//3、deleteRow(index):刪除表格的第index+1行;
//表格的行對象:
//1、cells屬性:返回當前行中的所有單元格,數組;
//2、rowIndex屬性:返回當前行在表格中的索引順序,從0開始;
//3、insertCell(index):在當前行的index+1處插入一個td;
//4、deleteCell(index):刪除當前行的第index+1個td;
//表格的單元格對象:
//1、cellIndex屬性:返回單元格在該行的索引順序,從0開始;
//2、innerHTML屬性:設置或者返回當前單元格中的HTMl代碼;
//3、align(valign)屬性:設置當前單元格的水平對齊方式;
//4、className屬性:設置單元格的class名稱。
function newRow(){
var book = prompt("書名:");
var price = prompt("價格:");
var table = document.getElementsByTagName("table");
//在表格的最后一行插入一個新行
var newRow = table[0].insertRow(table[0].rows.length-1);
//給新行設置單元格
var cell0 = newRow.insertCell(0);
cell0.innerHTML = book;
var cell1 = newRow.insertCell(1);
cell1.innerHTML = price;
getSum();
}
function deleteRow(){
var table = document.getElementsByTagName("table");
if(table[0].rows.length>2){
table[0].deleteRow(table[0].rows.length-2);
}else{
alert("刪刪刪!刪你妹啊刪!")
}
getSum();
}
function changeTitle(){
var color = prompt("請輸入6位十六進制顏色值:");
var table = document.getElementsByTagName("table");
table[0].rows[0].style = "background-color:#"+color;
}
function copyRow(){
var table = document.getElementsByTagName("table");
var copyRow = table[0].rows[table[0].rows.length-2].cloneNode(true);
var heJi = table[0].rows[table[0].rows.length-1];
//由於瀏覽器,自動將表格的<tr>包裹在<tbody>中
//所以<tr>實際並非<table>的子節點,故需取到<table>中的<tbody>進行插入;
if(table[0].rows.length>2){
table[0].getElementsByTagName("tbody")[0].insertBefore(copyRow,heJi);
}else{
alert("沒有可以復制的行");
}
getSum();
}
function getSum(){
//取到當前表格 表格所有行
var table = document.getElementsByTagName("table");
var rows = table[0].rows;
//
if(rows.length<=2){
rows[rows.length-1].cells[1].innerText = 0 + "元";
alert("沒有可計算的行!");
return;
}
//求和
var sum = 0 ;
for(var i = 1 ; i <= rows.length-2 ; i++){//第0行與最后一行舍棄1 rows.length-2
var cells = rows[i].cells;//取到單元格
sum += parseFloat(cells[cells.length-1].innerText);//最后一個單元格的 內容(innerText) 轉化成數字並求和計算!
}
rows[rows.length-1].cells[cells.length-1].innerText = sum.toFixed(2) + "元";
}
window.onload = function(){
getSum();
}
</script>
<style type="text/css">
table{
border-collapse: collapse;
width: 400px;
text-align: center;
color: #585858;
}
td,th{
border: 1px solid #8B8A8B;
}
table tr:last-child{
color: #E70014;
}
</style>
</head>
<body>
<table>
<tr>
<th>書名</th>
<th>價格</th>
</tr>
<tr>
<td>看得見風景的房間</td>
<td>30.00元</td>
</tr>
<tr>
<td>幸福從天而降</td>
<td>18.50元</td>
</tr>
<tr>
<td>60個瞬間</td>
<td>32.00元</td>
</tr>
<tr>
<td>合計</td>
<td></td>
</tr>
</table>
<br />
<button onclick="newRow()">增加一行</button>
<button onclick="deleteRow()">刪除最后一行</button>
<button onclick="changeTitle()">修改標題樣式</button>
<button onclick="copyRow()">復制最后一行</button>
</body>
</html>
(栗子:setTimeout/clearTimeout)
(栗子:setInterval/clearInterval)
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>首先是setTimeout與clearTimeout</title>
<!--要記得首先打開控制台喲~-->
<script type="text/javascript">
var timeoutid = setTimeout(function(){
console.log("setTimeout");
},5000) ;
function clearTimeoutBtn(){
clearTimeout(timeoutid);
}
</script>
</head>
<body>
<button onclick="clearTimeoutBtn()">clearTimeout</button>
</body>
</html>
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title>然后是setInterval與clearInterval</title> 6 <!--要記得首先打開控制台喲~--> 7 <script type="text/javascript"> 8 var num = 10; 9 var timeinterval = setInterval(function(){ 10 num--; 11 console.log(num); 12 if (num==0){ 13 clearInterval(timeinterval); 14 } 15 },1000) 16 function clearIntervalBtn(){ 17 clearInterval(timeinterval); 18 } 19 </script> 20 </head> 21 <body> 22 <button onclick="clearIntervalBtn()">clearIntervar</button> 23 </body> 24 </html>
js事件模型
1 DOM0事件模型
1.1 內聯模型:直接將函數名作為HTML標簽的某個事件屬性的屬性值; 栗子 <button onclick="func()"></button> 缺點:違反了W3C關於HTML與JS分離的基本原則!
1.2 腳本模型:在JS腳本中通過事件屬性進行綁定; 栗子 window.onload = function(){} 局限性:同一節點只能綁定一個同類型事件;
2 DOM2事件模型(后面有栗子!)
優點:同一節點,可以添加多個同類型事件的監聽器;
①添加事件綁定: IE10之前:btn1.attachEvent("onclick",函數); 其他瀏覽器:btn1.addEventListener("click",函數,true/false); true:表示事件捕獲;false(默認):表示事件冒泡 兼容寫法:if(btn1.attackEvent){btn1.attachEvent("onclick",函數);}else{btn1.addEventListener("click",函數,true/false);}
②取消事件綁定: .detachEvent("onclick",函數名); .removeEventListener("click",函數名); 注:如果取消時間幫頂,回調函數必須使用有名函數,而不能使用匿名函數。因為在取消事件幫頂時,需要傳入函數名;
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>這里是栗子</title>
<script type="text/javascript">
window.onload = function (){
var btn1 = document.getElementById("btn1");
function func1(){
alert(1);
}
function func2(){
alert(2);
}
btn1.addEventListener("click",func1,false);
btn1.addEventListener("click",func2,false);
var btn2 = document.getElementById("btn2");
btn2.addEventListener("click",function(){
btn1.removeEventListener("click",func1);
},false);
}
</script>
</head>
<body>
<button id="btn1">點我會彈窗!</button>
<br /><br />
<button id="btn2">點我不彈窗!</button>
</body>
</html>
JS中的事件流
1 事件冒泡
當某DOM元素觸發某事件時,會從當前DOM元素開始,逐個觸發其祖先元素的同類型事件,直到DOM根節點; DOM0事件流均為事件冒泡; IE中使用.attachEvent()事件,均為冒泡; 其他瀏覽器.addEventListener()添加的事件,當第三個參數為false時,為冒泡。
2 事件捕獲
當某DOM元素觸發某事件時,會從DOM根節點,逐個觸發其祖先元素的同類型事件,直到觸發到當前DOM元素開始;
只有使用.addEventListener()添加的事件,並且當第三個參數為true時,才進行捕獲。
3 阻止事件冒泡
IE瀏覽器:將e.cancelBubble屬性設為true; 其他瀏覽器:調用e.stopPropagation();方法
4 取消事件默認行為
IE瀏覽器:將e.returnValue屬性設為false; 其他瀏覽器:調用e.preventDefault(); 方法
(這里有栗子):
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>事件流舉栗</title>
<style type="text/css">
#div1{
width: 200px;
height: 200px;
background-color: #20B2AA;
color: #FFFFFF;
font-size: 20px;
font-weight: 700;
}
#div2{
width: 100px;
height: 100px;
background-color: #436690;
color: #FFFFFF;
font-size: 20px;
font-weight: 700;
}
#div3{
width: 50px;
height: 50px;
background-color: #4E2E83;
color: #FFFFFF;
font-size: 20px;
font-weight: 700;
}
</style>
</head>
<body>
<div id="div1">
<div id="div2">
<div id="div3">3</div>
</div>
</div>
<a href="../07 JS中的DOM/筆記.html" onclick="stopHref()">跳轉頁面</a>
</body>
<script type="text/javascript">
var div1 = document.getElementById("div1");
var div2 = document.getElementById("div2");
var div3 = document.getElementById("div3");
div1.addEventListener("click",function(e){
handleE();
console.log("div1觸發了click事件");
},false);
div2.addEventListener("click",function(e){
handleE();
console.log("div2觸發了click事件");
},false);
div3.addEventListener("click",function(e){
handleE();
console.log("div3觸發了click事件");
},false);
function handleE(e){
var evn = e||window.event;
evn.stopPropagation();
}
function stopHref(e){
e = e||window.event;
if (e.preventDefault) {
e.preventDefault(); //IE以外
} else {
e.returnValue = false; //IE
}
alert("好氣呀!");
}
</script>
</html>
