欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實例?ODO?List分析

 更新時間:2022年01月26日 16:52:40   作者:程序員云錦  
這篇文章主要介紹了JavaScript實例?ODO?List分析,主要利用JavaScript、css、HTML等實例代碼展開起內(nèi)容的解析,需要的小伙伴可以參考一下

一、實例代碼

HTML

<!DOCTYPE html>
<html lang="en">
<head>
? <meta charset="UTF-8">
? <meta http-equiv="X-UA-Compatible" content="IE=edge">
? <meta name="viewport" content="width=device-width, initial-scale=1.0">
? <title>Document</title>
? <style>

? </style>
</head>

<body>
? <div id="myDIV" class="header">
? ? <h2 style="margin:5px">My To Do List</h2>
? ? <input type="text" id="myInput" placeholder="Title...">
? ? <span onclick="newElement()" class="addBtn">Add</span>
? </div>
??
? <ul id="myUL">
? ? <li>Hit the gym</li>
? ? <li class="checked">Pay bills</li>
? ? <li>Meet George</li>
? ? <li>Buy eggs</li>
? ? <li>Read a book</li>
? ? <li>Organize office</li>
? </ul>
? <script>

? </script>
</body>
</html>

CSS

body {
? margin: 0;/*清除默認外邊距*/
? min-width: 250px;/*設置一個最小寬度*/
}

* {
? box-sizing: border-box;/*采用怪異盒模型*/
}


ul {/*清除默認內(nèi)外邊距*/
? margin: 0;
? padding: 0;
}


ul li {
??
? cursor: pointer;/*鼠標移上時變成手*/
? position: relative;/*相對于父級元素進行定位*/
? padding: 12px 8px 12px 40px;/*內(nèi)邊距*/
? background: #eee;/*背景顏色*/
? font-size: 18px;/*文字大小*/
? transition: 0.2s;
??
? /*下面四個是一個意思,使元素及子元素的文本不可選中*/
? -webkit-user-select: none;
? -moz-user-select: none;
? -ms-user-select: none;
? user-select: none;
}


ul li:nth-child(odd) {/*odd是奇數(shù),這里是為了把奇偶項的背景顏色不同*/
? background: #f9f9f9;
}


ul li:hover {/*鼠標移上的項變色*/
? background: #ddd;
}


ul li.checked {/*已經(jīng)做完的項*/
? background: #888;/*背景顏色*/
? color: #fff;/*文本顏色*/
? text-decoration: line-through;/*刪除線*/
}


ul li.checked::before {/*偽元素*/
? content: '';/*不寫內(nèi)容偽元素無法生效*/
? position: absolute;/*絕對定位,定位依據(jù)是li*/
? border-color: #fff;/*邊框顏色*/
? border-style: solid;/*邊框風格*/
? border-width: 0 2px 2px 0;/*邊框?qū)挾?/
? top: 10px;/*頂部*/
? left: 16px;/*左邊*/
? transform: rotate(45deg);/*旋轉(zhuǎn),形成√*/
? height: 15px;/*高度*/
? width: 7px;/*寬度*/
}

.close {
? position: absolute;/*絕對定位*/
? /*移動到最*/
? right: 0;
? top: 0;
? padding: 12px 16px 12px 16px;/*內(nèi)邊距*/
}

.close:hover {/*鼠標移上去的時候*/
? background-color: #f44336;/*背景顏色*/
? color: white;/*對勾的顏色*/
}


.header {/*定義標題樣式*/
? background-color: #f44336;/*背景顏色*/
? padding: 30px 40px;/*內(nèi)邊距*/
? color: white;/*文字顏色*/
? text-align: center;/*文字水平居中*/
}


.header:after {
? content: "";
? display: table;
? clear: both;
}


input {
? border: none;/*清除默認邊框樣式*/
? width: 75%;/*寬度為父級的75%*/
? padding: 10px;/*內(nèi)邊距*/
? float: left;/*左浮動*/
? font-size: 16px;/*字體大小*/
}


.addBtn {/*定義添加按鈕樣式*/
? padding: 9px;
? width: 25%;
? background: #d9d9d9;
? color: #555;
? float: left;
? text-align: center;
? font-size: 16px;
? cursor: pointer;/*鼠標變成手*/
? transition: 0.3s;
}


.addBtn:hover {
? background-color: #bbb;/*鼠標移上時*/
}?

JavaScript

// Create a "close" button and append it to each list item
var myNodelist = document.getElementsByTagName("LI");
var i;
for (i = 0; i < myNodelist.length; i++) {
? var span = document.createElement("SPAN");
? var txt = document.createTextNode("\u00D7");
? span.className = "close";
? span.appendChild(txt);
? myNodelist[i].appendChild(span);
}

// Click on a close button to hide the current list item
var close = document.getElementsByClassName("close");
var i;
for (i = 0; i < close.length; i++) {
? close[i].onclick = function() {
? ? var div = this.parentElement;
? ? div.style.display = "none";
? }
}

// Add a "checked" symbol when clicking on a list item
var list = document.querySelector('ul');
list.addEventListener('click', function(ev) {
? if (ev.target.tagName === 'LI') {
? ? ev.target.classList.toggle('checked');
? }
}, false);

// Create a new list item when clicking on the "Add" button
function newElement() {
? var li = document.createElement("li");
? var inputValue = document.getElementById("myInput").value;
? var t = document.createTextNode(inputValue);
? li.appendChild(t);
? if (inputValue === '') {
? ? alert("You must write something!");
? } else {
? ? document.getElementById("myUL").appendChild(li);
? }
? document.getElementById("myInput").value = "";

? var span = document.createElement("SPAN");
? var txt = document.createTextNode("\u00D7");
? span.className = "close";
? span.appendChild(txt);
? li.appendChild(span);

? for (i = 0; i < close.length; i++) {
? ? close[i].onclick = function() {
? ? ? var div = this.parentElement;
? ? ? div.style.display = "none";
? ? }
? }
}

二、實例演示

頁面加載后顯示TODO List的頁面

點擊可以把列表的某一項會自動用刪除線標識,表示事情已經(jīng)做完了

點擊每一項的最右邊有刪除事項的“叉叉”,點擊可以刪除事項

最后在最上方的輸入框輸入事項的內(nèi)容,然后點擊右側(cè)的Add按鈕,可以把事項內(nèi)容增加到下方列表中

點擊Add按鈕后

事項添加成功

三、實例剖析

var myNodelist = document.getElementsByTagName("LI");
var i;
for (i = 0; i < myNodelist.length; i++) {
? var span = document.createElement("SPAN");
? var txt = document.createTextNode("\u00D7");
? span.className = "close";
? span.appendChild(txt);
? myNodelist[i].appendChild(span);
}

這一部分是加載頁面之后,在列表每一個事項的最后生成一個’×’的圖標,用于提示用戶可以點擊刪除

要注意: ’\u00D7’是Unicode編碼,代表的就是’x’這個符號

var close = document.getElementsByClassName("close");
var i;
for (i = 0; i < close.length; i++) {
? close[i].onclick = function() {
? ? var div = this.parentElement;
? ? div.style.display = "none";
? }
}

這部分先獲取類名為close的dom元素,同時也是’x’那個元素,獲取到元素集合后,做一個循環(huán),給每一個元素的onclick屬性綁定函數(shù)

close[i].onclick = function() {
? ? var div = this.parentElement;
? ? div.style.display = "none";
}

如果有點擊動作,則直接通過修改display來使事項隱藏,在用戶看來就是直接將事項刪除了

var list = document.querySelector('ul');
list.addEventListener('click', function(ev) {
? if (ev.target.tagName === 'LI') {
? ? ev.target.classList.toggle('checked');
? }
}, false);

這一部分是實現(xiàn)當用戶點擊某個事項時,給相應的被點擊的事項添加’checked’類名來改變相應的樣式

function newElement() {
? var li = document.createElement("li");
? var inputValue = document.getElementById("myInput").value;
? var t = document.createTextNode(inputValue);
? li.appendChild(t);
? if (inputValue === '') {
? ? alert("You must write something!");
? } else {
? ? document.getElementById("myUL").appendChild(li);
? }
? document.getElementById("myInput").value = "";
}

最后這一部分是添加新的事項,首先Add按鈕的onclick屬性綁定newElement()函數(shù),點擊Add之后執(zhí)行newElement函數(shù),生成新的li標簽,并且把輸入框內(nèi)的內(nèi)容也作為li標簽的文本,生成之后添加到列表最下面

var span = document.createElement("SPAN");
? var txt = document.createTextNode("\u00D7");
? span.className = "close";
? span.appendChild(txt);
? li.appendChild(span);

? for (i = 0; i < close.length; i++) {
? ? close[i].onclick = function() {
? ? ? var div = this.parentElement;
? ? ? div.style.display = "none";
? ? }
? }

創(chuàng)建新的li標簽后,需要配套的給新的li標簽的最后面也添加一個’x’符號,并且給onclick屬性綁定上函數(shù)

到此這篇關于JavaScript實例 ODO List分析的文章就介紹到這了,更多相關 ODO List分析內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Javascript閉包使用場景原理詳細

    Javascript閉包使用場景原理詳細

    這篇文章主要介紹了Javascript閉包的使用場景,  由于在Javascript語言中,只有函數(shù)內(nèi)部的子函數(shù)才能讀取局部變量,閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)。所以,在本質(zhì)上,閉包就是將函數(shù)內(nèi)部和函數(shù)外部連接起來的一座橋梁,下面一起進入文化在哪個了解文章內(nèi)容
    2021-11-11
  • 微信小程序中form 表單提交和取值實例詳解

    微信小程序中form 表單提交和取值實例詳解

    這篇文章主要介紹了微信小程序中form 表單提交和取值實例詳解的相關資料,需要的朋友可以參考下
    2017-04-04
  • pnpm?tauri?build?默認com.tauri.dev打包報錯解決

    pnpm?tauri?build?默認com.tauri.dev打包報錯解決

    這篇文章主要介紹了pnpm?tauri?build?默認com.tauri.dev打包報錯解決方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • Promise靜態(tài)四兄弟實現(xiàn)示例詳解

    Promise靜態(tài)四兄弟實現(xiàn)示例詳解

    這篇文章主要為大家介紹了Promise靜態(tài)四兄弟實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 8個JS的reduce使用實例和reduce操作方式

    8個JS的reduce使用實例和reduce操作方式

    reduce方法是JavaScript中一個比較強大的方法,可能在平時開發(fā)中,有人根本沒用過,通過下面的8個例子,學會reduce的用法以及它的常用場景,需要的朋友可以參考一下
    2021-09-09
  • js解決移動端滾動穿透問題方案詳解

    js解決移動端滾動穿透問題方案詳解

    這篇文章主要為大家介紹了js解決移動端滾動穿透問題方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • Js視頻播放器插件Video.js使用方法詳解

    Js視頻播放器插件Video.js使用方法詳解

    Video.js 是一個通用的在網(wǎng)頁上嵌入視頻播放器的JS庫,Video.js自動檢測瀏覽器對HTML5的支持情況,如果不支持HTML5則自動使用Flash 播放器,推薦大家好好看看
    2020-02-02
  • 一款功能強大的markdown編輯器tui.editor使用示例詳解

    一款功能強大的markdown編輯器tui.editor使用示例詳解

    這篇文章主要為大家介紹了一款功能強大的markdown編輯器tui.editor使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • sessionStorage多Tab標簽頁數(shù)據(jù)共享問題分析

    sessionStorage多Tab標簽頁數(shù)據(jù)共享問題分析

    這篇文章主要為大家介紹了sessionStorage多Tab標簽頁數(shù)據(jù)共享問題分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • electron渲染進程主進程相互傳值示例解析

    electron渲染進程主進程相互傳值示例解析

    這篇文章主要為大家介紹了electron渲染進程主進程相互傳值示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02

最新評論