中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用Javascript怎么編寫一個單選框功能

發布時間:2020-12-10 14:21:42 來源:億速云 閱讀:347 作者:Leah 欄目:開發技術

本篇文章為大家展示了利用Javascript怎么編寫一個單選框功能,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

1.事件委托

事件委托: 事件代理, 將子節點要做的事情交給父元素來做

原理: 將原來要給子元素添加的事件, 加給父元素, 事件中通過 target || srcElement 找到對應的子節點, 子節點處理具體的操作

優點: 避免使用for 后續加進來的元素也有同樣的事件處理

使用: 如果子節點有統一的事件(每一個li都加點擊事件 每一個li都輸出元素)

ul.onclick = function(evs){
 var ev = window.event || evs;
 // console.log(ev.target || ev.srcElement);
 var tar = ev.target || ev.srcElement;
 tar.style.background = 'red';
}

// 創建節點
var li = document.createElement('li');
li.innerHTML = '12345';
// 追加進去
ul.appendChild(li);

2.阻止冒泡

由于冒泡產生的問題 阻止冒泡解決

依賴于事件對象

標準: ev.stopPropagation();

​ ie: ev.cancelBubble = true;

一個是方法 一個是屬性 需要做兼容

判斷方法是否存在:

ev.stopPropagation ? ev.stopPropagation() : ev.cancelBubble = true;

不想讓哪一個事件冒泡,就在那一個元素的事件上阻止

代碼實現:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>模擬單選框</title>
 <style>
  *{
   margin: 0;
   padding: 0;
  }
  div{
   width: 260px;
   height: 30px;
   border: 1px solid #0000ff;
   margin: 40px auto;
   font: 14px/30px "微軟雅黑";
   text-indent: 5px;
  }
  ul{
   width: 260px;
   height: 150px;
   border: 1px solid #0000ff;
   margin: -40px auto;
   display: none;
  }
  ul > li{
   list-style: none;
   width: 100%;
   height: 30px;
   font: 14px/30px "微軟雅黑";
   text-indent: 5px;
  }
  ul > li:hover{
   color:#fff5bd;
   background: #fe6601;
  }
 </style>
</head>
<body>
 <!-- 1.布局: div 和 列表 并且劃上加背景色 -->
 <div id="content"></div>
 <ul>
  <li>HTML</li>
  <li>CSS</li>
  <li>JavaScript</li>
  <li>HTML5</li>
  <li>CSS3</li>
 </ul>
 <script>
  // 點擊每一個li 將li的內容賦值給 div 給當前點擊的li加上背景色
  // 點擊空白部分隱藏
  // 1.當鼠標移入div時, ul顯示, 反之ul隱藏
  // 獲取div, ul
  var div = document.querySelector('div');
  var ul = document.querySelector('ul');
  var lis = ul.getElementsByTagName('li');
  console.log(div, ul, lis);
  // 鼠標移入div時, ul顯示, onmouseenter不會觸發父元素事件
  div.onmouseenter = function(){
   ul.style.display = 'block';
   /* 將li的內容賦值給 div 給當前點擊的li加上背景色
   獲取點擊的li的值 */  
   // 獲取ul點擊事件
   ul.onclick = function(evs){
    // 增加排他操作
    for(var i = 0; i < lis.length; i++){
     lis[i].style.background = '#ffffff';
     lis[i].style.color = '#000000';
    }
    // 獲取事件
    var ev = window.event || evs;
    // 阻止冒泡
    ev.stopPropagation &#63; ev.stopPropagation() : ev.cancelBubble = true;
    // console.log(ev.target || ev.srcElement);
    // 獲取事件的觸發源
    var tar = ev.target || ev.srcElement;
    // div的內容更改為相對應觸發源的內容
    div.innerHTML = tar.innerHTML;
    // 給當前點擊的li加上背景色
    tar.style.background = '#0000FF';
    tar.style.color = '#fff5bd';
   }
  }
  // 點擊空白處隱藏
  document.onclick = function(){
   // ul消失
   ul.style.display = 'none';
   // div的值設為空
   div.innerHTML = '';
   // 所有li恢復原來樣式 
   for(var i = 0; i < lis.length; i++){
    lis[i].style.background = '#ffffff';
    lis[i].style.color = '#000000';
   }
  }
  // 給每一個li添加劃上屬性
  for(var i = 0; i < lis.length; i++){
   // 為li添加劃上事件
   lis[i].onmouseenter = function(){
    this.style.background = '#fe6601';
    this.style.color = '#fff5bd';
   }
   // 為li添加劃出事件, 恢復為默認樣式
   lis[i].onmouseleave = function(){
    this.style.background = '#ffffff';
    this.style.color = '#000000';
   }
  }
 </script>
</body>
</html>

上述內容就是利用Javascript怎么編寫一個單選框功能,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清河县| 永顺县| 建阳市| 屏南县| 衡水市| 柏乡县| 乐平市| 吉安县| 正安县| 英山县| 景东| 嘉祥县| 滦南县| 资中县| 阳原县| 德钦县| 白城市| 云林县| 通道| 长治县| 定远县| 霍邱县| 鸡西市| 健康| 历史| 泾阳县| 沙洋县| 衡东县| 大宁县| 茂名市| 炎陵县| 历史| 青龙| 浦东新区| 黄梅县| 湘乡市| 微山县| 南宫市| 肃宁县| 潮州市| 库尔勒市|