仿餓了么詳情頁 左右聯(lián)動(dòng) vue+jquery

今天撵幽, 給大家分享一個(gè)仿餓了么商品詳情頁的左右聯(lián)動(dòng)
本方法是通過 jquery.js + vue.js 來實(shí)現(xiàn)的痴荐,小伙伴們不要忘記引入哦

HTML:

<body>
    <div class="header"></div>
    <div class="swiper-container">
        <!-- 商品 <-> 詳情 -->
        <ul class="swiper-container-ul">
            <li class="swiper-container-ul-li actives">商品</li>
            <li class="swiper-container-ul-li">詳情</li>
        </ul>

        <!---->
        <div class="swiper-wrapper">
            <div class="content">
                <!--左側(cè)-->
                <div class="left" id="left">
                    <ul>
                        <li v-for="item in items">{{item.name}}</li>
                    </ul>
                </div>

                <!--右側(cè)-->
                <div class="right" id="right">
                    <ul>
                        <li v-for="item in items">{{item.name}}
                            <div class="class-title">{{item.class}}</div>
                            <div v-for="ite in item.list">
                                <div class="item">
                                    <div class="item-left">
                                        <div class="item-img"></div>
                                    </div>
                                    <div class="item-right">
                                        <div class="title">{{ite.title}}</div>
                                    </div>
                                </div>
                            </div>

                        </li>

                    </ul>
                </div>
            </div>
        </div>
    </div>
</body>

css:

*{
  padding: 0;
  margin: 0;
}
.header{
  width: 100%;
  height: 150px;
  background: #555;
}
.swiper-container-ul{
  list-style: none;
  overflow: hidden;
  width: 100%;
  background: #fff;
  top: 0;
}
.swiper-container-ul-li{
  width: 50%;
  height: 40px;
  line-height: 40px;
  float: left;
  text-align: center;
}
.actives{
  border-bottom: 1px solid #3190e8;
  color: #3190e8;
}
.content{
  width: 100%;
  overflow: hidden;
}
.left{
  top: 41px;
  float: left;
  width: 25%;
  height: 100%;
  background: #eee;
}
.left ul{
  list-style: none;
}
.left ul li{
  padding: 15px 5px;
  text-align: center;
}
.active{
  background: #fff;
  border-left: 2px solid #3190e8;
}
.right{
  float: left;
  width: 75%;
  height: 100%;
}
.right ul{
  list-style: none;
}
.class-title{
  padding: 7px 10px;
  background: #eee;
}
.item{
  overflow: hidden;
  width: 100%;
  padding: 10px;
  background: #fff;
  border-bottom: 1px solid #eee;
}
.item-left{
  float: left;
}
.item-right{
  float: left;
  padding: 0 10px;
}
.item-img{
  width: 100px;
  height: 100px;
  background: #eee;
}
.title{
  width: 100px;
  height: 20px;
  margin-top: 10px;
  background: #eee;
}
.subtitle{
  width: 70px;
  height: 20px;
  margin-top: 10px;
  background: #eee;
}
.price{
  width: 50px;
  height: 20px;
  margin-top: 10px;
  background: #eee;
}

JS:

<script>
    $(function () {
        $('.content').css('height',$('right').height)
        $('.left ul li').eq(0).addClass('active');

        $(window).scroll(function () {
            // 這里在滾動(dòng)的時(shí)候做監(jiān)聽,如果翻上去的部分超過150的時(shí)候烘豌,切換商品和左側(cè)這里做絕對(duì)定位华蜒,然后右側(cè)的margin-left設(shè)置成左側(cè)的寬度

            if($(window).scrollTop()>= 150){
                $('.swiper-container-ul').css('position','fixed');
                $('.left').css('position','fixed')
                $('.right').css('margin-left',$('.left').width());
            }else{
                $('.swiper-container-ul').css('position','')
                $('.left').css('position','')
                $('.right').css('margin-left','')
            }

            // 獲取右側(cè)當(dāng)前l(fā)i距離頂端的高度 - 右側(cè)已經(jīng)翻上去的高度 - head的高度
            $('.right ul li').each(function () {
                var target = parseInt($(this).offset().top - $(window).scrollTop() - 150)
                console.log($(this))
                var i = $(this).index()

            // if target<=0 清除所又li的active, 給當(dāng)前l(fā)i賦予active

                if(target<=0){
                    $('.left ul li').removeClass('active');
                    $('.left ul li').eq(i).addClass('active')
                }
            })
        })


        // 點(diǎn)擊左側(cè)li通過下標(biāo)找到相應(yīng)li的位置辙纬,通過animate滾動(dòng)到相應(yīng)的位置
        $('.left ul li').click(function () {
            var i = $(this).index('.left ul li')
            $('body,html').animate({scrollTop: $('.right ul li').eq(i).offset().top-40},1000)
        })
    })
</script>
<script>
    var left = new Vue({
        el: '#left',
        data: {
            items: [
                { name : '分類1' },
                { name : '分類2' },
                { name : '分類3' },
                { name : '分類4' },
                { name : '分類5' },
                { name : '分類6' },
                { name : '分類7' },
                { name : '分類8' }
            ]
        }
    });
    var right = new Vue({
        el: '#right',
        data: {
            items: [
                { class : '分類1',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類2',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類3',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類4',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類5',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類6',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類7',list : [ { title : '1' },{ title : '2' } ] },
                { class : '分類8',list : [ { title : '1' },{ title : '2' } ] }
            ]
        }
    });
</script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市叭喜,隨后出現(xiàn)的幾起案子贺拣,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件譬涡,死亡現(xiàn)場離奇詭異闪幽,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)涡匀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門盯腌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人陨瘩,你說我怎么就攤上這事羡铲⊥ィ” “怎么了末患?”我有些...
    開封第一講書人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵军洼,是天一觀的道長。 經(jīng)常有香客問我甚淡,道長大诸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任贯卦,我火速辦了婚禮资柔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘撵割。我一直安慰自己建邓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開白布睁枕。 她就那樣靜靜地躺著官边,像睡著了一般。 火紅的嫁衣襯著肌膚如雪外遇。 梳的紋絲不亂的頭發(fā)上注簿,一...
    開封第一講書人閱讀 49,792評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音跳仿,去河邊找鬼诡渴。 笑死,一個(gè)胖子當(dāng)著我的面吹牛菲语,可吹牛的內(nèi)容都是我干的妄辩。 我是一名探鬼主播,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼山上,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼眼耀!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起佩憾,我...
    開封第一講書人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤哮伟,失蹤者是張志新(化名)和其女友劉穎干花,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體楞黄,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡池凄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鬼廓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肿仑。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖碎税,靈堂內(nèi)的尸體忽然破棺而出尤慰,到底是詐尸還是另有隱情,我是刑警寧澤蚣录,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站眷篇,受9級(jí)特大地震影響萎河,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蕉饼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一虐杯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧昧港,春花似錦擎椰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至叹侄,卻和暖如春巩搏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背趾代。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工贯底, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人撒强。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓禽捆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親飘哨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子胚想,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348