亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Javascript實現(xiàn)單選框效果

 更新時間:2020年12月09日 15:55:59   作者:夾心776655  
這篇文章主要為大家詳細介紹了Javascript實現(xiàn)單選框效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Javascript實現(xiàn)單選框效果的具體代碼,供大家參考,具體內容如下

描述: 點擊每一個li 將li的內容賦值給 div 給當前點擊的li加上背景色, 點擊空白部分隱藏

技術要點:

1.事件委托

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

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

優(yōu)點: 避免使用for 后續(xù)加進來的元素也有同樣的事件處理

使用: 如果子節(jié)點有統(tǒng)一的事件(每一個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';
}

// 創(chuàng)建節(jié)點
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;

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

代碼實現(xiàn):

<!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不會觸發(fā)父元素事件
  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 ? ev.stopPropagation() : ev.cancelBubble = true;
    // console.log(ev.target || ev.srcElement);
    // 獲取事件的觸發(fā)源
    var tar = ev.target || ev.srcElement;
    // div的內容更改為相對應觸發(fā)源的內容
    div.innerHTML = tar.innerHTML;
    // 給當前點擊的li加上背景色
    tar.style.background = '#0000FF';
    tar.style.color = '#fff5bd';
   }
  }
  // 點擊空白處隱藏
  document.onclick = function(){
   // ul消失
   ul.style.display = 'none';
   // div的值設為空
   div.innerHTML = '';
   // 所有l(wèi)i恢復原來樣式 
   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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • js實現(xiàn)同一頁面多個不同運動效果的方法

    js實現(xiàn)同一頁面多個不同運動效果的方法

    這篇文章主要介紹了js實現(xiàn)同一頁面多個不同運動效果的方法,涉及javascript同時實現(xiàn)多個效果的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • JAVASCRIPT keycode總結

    JAVASCRIPT keycode總結

    JAVASCRIPT中keycode總結,方便需要控制keycode的朋友
    2009-02-02
  • JavaScript實現(xiàn)的浮動層框架用法實例分析

    JavaScript實現(xiàn)的浮動層框架用法實例分析

    這篇文章主要介紹了JavaScript實現(xiàn)的浮動層框架用法,以實例形式分析了JavaScript實現(xiàn)可關閉的半透明浮動層相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • js 淘寶首頁的拼音排序效果

    js 淘寶首頁的拼音排序效果

    模仿淘寶首頁的拼音排序效果代碼。
    2009-05-05
  • 有關js的變量作用域和this指針的討論

    有關js的變量作用域和this指針的討論

    在ECMAScript中,只有兩種執(zhí)行環(huán)境,全局環(huán)境和函數(shù)環(huán)境,每個函數(shù)都是一個執(zhí)行環(huán)境,包括嵌套函數(shù)。換句話說,其他情況下即使變量聲明在一對大括號中,在括號外部仍然可以訪問這些變量
    2010-12-12
  • JavaScript中第三方庫Apollo的使用詳解

    JavaScript中第三方庫Apollo的使用詳解

    Apollo 是一個廣泛使用的 JavaScript 第三方庫,主要用于構建與 GraphQL API 交互的應用程序,下面就跟隨小編一起來學習一下它的具體應用吧
    2024-02-02
  • 在子窗口中關閉父窗口的一句代碼

    在子窗口中關閉父窗口的一句代碼

    在子窗口中關閉父窗口在某些特殊的情況下還是有存在的必要的,其實很簡單,只需一句代碼便可實現(xiàn),感興趣的朋友可以了解下
    2013-10-10
  • JavaScript中最常用的10種代碼簡寫技巧總結

    JavaScript中最常用的10種代碼簡寫技巧總結

    這篇文章主要總結了JavaScript中最常用的10種代碼簡寫技巧的相關資料,其中包括三元操作符、短路求值簡寫方式、聲明變量簡寫方法、if存在條件簡寫方法及JavaScript循環(huán)簡寫方法等等,分別給出了詳細的示例代碼供大家參考,需要的朋友們下面來一起看看吧。
    2017-06-06
  • layui按條件隱藏表格列的實例

    layui按條件隱藏表格列的實例

    今天小編就為大家分享一篇layui按條件隱藏表格列的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JS算法教程之字符串去重與字符串反轉

    JS算法教程之字符串去重與字符串反轉

    這篇文章主要給大家介紹了關于JS算法教程之字符串去重與字符串反轉的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12

最新評論