進(jìn)階任務(wù)10(主線任務(wù)):事件的應(yīng)用

題目1: 實(shí)現(xiàn)如下圖Tab切換的功能


Tab切換效果
    <style>
        ul,li{
            margin:0;
            padding:0;
        }
        li{
            list-style:none;
        }
        .clearfix:after{
            content:'';
            display:block;
            clear:both;
        }
        .tab{
            width:600px;
            margin:20px auto;
            border:1px dashed #ccc;
            padding:20px 10px;
            border-radius:5px;
        }   
        .tab-header{
            border-bottom:1px solid #ccc;
        }
        .tab-header>li{
            float:left;
            color:#cfcfcf;
            border-top:1px solid #fff;
            border-left:1px solid #fff;
            border-right:1px solid #fff;
            padding:10px 20px;
            cursor:pointer;
        }
        .tab-header .active{
            border:1px solid #ccc;
            border-bottom:#fff;
            border-radius:5px 5px 0  0;
            color:#333;
            background:#c3c3ce;
            margin-bottom:-1px;
        }
        .tab-container{
            padding:20px 10px;

        }
        .tab-container>li{
            display:none;
        }
        .tab-container>.active{
            display:block;
        }
        .box{
            height:1000px;
        }
    </style>
</head>
<body>
<div class="tab">
    <ul class="tab-header clearfix">
        <li class="active">tab1</li>
        <li>tab2</li>
        <li>tab3</li>
    </ul>
    <ul class="tab-container">
        <li class="active">內(nèi)容1</li>
        <li>內(nèi)容2</li>
        <li>內(nèi)容3</li>
    </ul>
</div>
<div class="box"></div>
<script>
    var tabHeader=document.querySelector('.tab-header'),
            tabLis=document.querySelectorAll('.tab-header>li'),
            tabPanels=document.querySelectorAll('.tab-container>li');

    tabHeader.addEventListener('click',function(e){
        var clickNode=e.target;
        if(clickNode.tagName.toLowerCase()==='li'){
            for(var i=0;i<tabLis.length;i++){
                tabLis[i].classList.remove('active');
            }
            clickNode.classList.add('active');

            var index=[].indexOf.call(tabLis,clickNode);
            console.log(index);

            for(var i=0;i<tabPanels.length;i++){
                tabPanels[i].classList.remove('active');
            }
            tabPanels[index].classList.add('active');
        }
    })
</script>

題目2:實(shí)現(xiàn)下圖的模態(tài)框功能,點(diǎn)擊模態(tài)框不隱藏干像,點(diǎn)擊關(guān)閉以及模態(tài)框以外的區(qū)域模態(tài)框隱藏


模態(tài)框
<div class="btn-group">
    <button id="btn-modal">點(diǎn)我</button>
</div>
<div id="modal-1" class="modal-dialog">
    <div class="cover"></div>
    <div class="modal-ct">
        <div class="header">
            <h3>標(biāo)題</h3>
            <a class="close" href="#">x</a>
        </div>
        <div class="content">
            <p>內(nèi)容1</p>
            <p>內(nèi)容2</p>
            <p>內(nèi)容3</p>
        </div>
        <div class="footer">
            <a class="btn btn-confirm" href="#">確定</a>
            <a class="btn btn-cancel" href="#">取消</a>
        </div>
    </div>
</div>

<script>

var btn=document.querySelector('#btn-modal'),
        modal=document.querySelector('#modal-1'),
        modalCt=document.querySelector('#modal-1 .modal-ct');


btn.addEventListener('click',function(e){
    e.stopPropagation();
    showModal(modal);
});

modalCt.addEventListener('click',function(e){
    e.stopPropagation();
    if(hasClass(e.target,'close')||hasClass(e.target,'btn-cancel')){
        hideModal(modal);
    }
});

document.body.addEventListener('click',function(){
    hideModal(modal);
});

function showModal(modal){
    modal.style.display='block';
}
function hideModal(modal){
    modal.style.display="none";
}
function hasClass(ele,cls){
    return !!ele.className.match(new RegExp('\\b'+cls+'\\b'));
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末卤橄,一起剝皮案震驚了整個(gè)濱河市警医,隨后出現(xiàn)的幾起案子乌妒,更是在濱河造成了極大的恐慌,老刑警劉巖追葡,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件腺律,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡宜肉,警方通過(guò)查閱死者的電腦和手機(jī)匀钧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)谬返,“玉大人之斯,你說(shuō)我怎么就攤上這事∏猜粒” “怎么了佑刷?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵莉擒,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我项乒,道長(zhǎng)啰劲,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任檀何,我火速辦了婚禮,結(jié)果婚禮上廷支,老公的妹妹穿的比我還像新娘频鉴。我一直安慰自己,他們只是感情好恋拍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布垛孔。 她就那樣靜靜地躺著,像睡著了一般施敢。 火紅的嫁衣襯著肌膚如雪周荐。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,598評(píng)論 1 305
  • 那天僵娃,我揣著相機(jī)與錄音概作,去河邊找鬼。 笑死默怨,一個(gè)胖子當(dāng)著我的面吹牛讯榕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播匙睹,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼愚屁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了痕檬?” 一聲冷哼從身側(cè)響起霎槐,我...
    開(kāi)封第一講書(shū)人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎梦谜,沒(méi)想到半個(gè)月后丘跌,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡改淑,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年碍岔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片朵夏。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蔼啦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出仰猖,到底是詐尸還是另有隱情捏肢,我是刑警寧澤奈籽,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站鸵赫,受9級(jí)特大地震影響衣屏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜辩棒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一狼忱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧一睁,春花似錦钻弄、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至复凳,卻和暖如春瘤泪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背育八。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工对途, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人单鹿。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓掀宋,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親仲锄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子劲妙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,152評(píng)論 25 707
  • 1- 實(shí)現(xiàn)如下圖Tab切換的功能 代碼/預(yù)覽:Tab切換功能 2- 實(shí)現(xiàn)下圖的模態(tài)框功能,點(diǎn)擊模態(tài)框不隱藏儒喊,點(diǎn)擊關(guān)...
    osborne閱讀 469評(píng)論 0 1
  • 實(shí)現(xiàn)Tab切換的功能 實(shí)現(xiàn)下圖的模態(tài)框功能镣奋,點(diǎn)擊模態(tài)框不隱藏,點(diǎn)擊關(guān)閉以及模態(tài)框以外的區(qū)域模態(tài)框隱藏
    RookieD閱讀 376評(píng)論 0 0
  • 不知道是因?yàn)橥砩虾攘怂浛Х冗€是什么其他有毛病的原因,我竟然很想寫(xiě)點(diǎn)什么芯义。今天約了外在美少女晚飯哈垢,湊巧的是11因?yàn)?..
    孫狗閱讀 645評(píng)論 0 50
  • 作者:鄭毅 地點(diǎn):臺(tái)北一路 時(shí)間:2017.5.11 22:55 回顧這幾年的經(jīng)歷,驀然發(fā)現(xiàn)這一路出現(xiàn)在我生命中的...
    zy一往直前閱讀 215評(píng)論 0 0