2023年4月1日
vue-scrollList垂直滚动列表组件封装
前段时间做了一个web小程序项目,业务上有垂直滚动列表需求,所以咱就开始动手拆分-封装。

父组件:
<!-- 拼团content -->
<div v-if="data.activityGroup">
<div class="bl-group-bg">
<p class="bl-group-people">{{data.assest_data.length}}人在拼单 可直接参与</p>
<div class="bl-group-wrap">
<Scroll :id="'service'">
<template>
<div v-for="(item,index) in data.assest_data" :key="index">
<div class="group-left">
<image class="user-head" :src="item.headImg"></image>
<p class="user-name">{{item.name}}</p>
</div>
<div class="group-right">
<div class="group-state">
<p class="order-people">还差<span class="people-num">{{item.lack}}</span>人
</p>
<p class="order-time">
<!-- <span class="time-text">{{ timeout != 0 ? `剩余${timeout}`: `本次活动已结束`}}</span> -->
<span class="time-text">{{ timeout != 0 && timeoutList[index] ? `剩余${timeoutList[index]}`: `本次活动已结束`}}</span>
<!-- <countDown :endTime="item.endTime" :endText="item.endText"
class="time-text" :end-tip="'scroll'" /> -->
</p>
</div>
<div class="go-join-btn" v-if="timeout != 0 && timeoutList[index]">
<p class="go-join-text" @click="joinBuying(item,index)">去拼单</p>
</div>
</div>
</div>
</template>
</Scroll>
</div>
</div>
</div>
<script>
import Scroll from "../components/scrollList/scrollList.vue"
export default {
components: {
Scroll,
},
data: {
assest_data: [{
headImg: '../../../static/images/groupBuyingDetail/bl_share_icon5.png', //头像
name: '微信用户', //名字
lack: 1, //缺少多少人可以拼单
endTime: new Date("2023/03/27 01:00:00").getTime() / 1000 + ' ',
endText: '',
},
{
headImg: '../../../static/images/groupBuyingDetail/bl_service_icon.png',
name: '微***',
lack: 2, //缺少多少人
endTime: new Date("2023/04/16 12:00:00").getTime() / 1000 + ' ',
endText: '',
},
{
headImg: '../../../static/images/groupBuyingDetail/bl_home_icon.png',
name: '微***',
lack: 3, //缺少多少人
endTime: new Date("2023/04/15 06:00:00").getTime() / 1000 + ' ',
endText: '',
},
// {
// headImg: '../../../static/images/groupBuyingDetail/bl_share_icon5.png',
// name: '微***',
// lack: 4, //缺少多少人
// endTime: new Date("2023/04/14 09:00:00").getTime() / 1000 + ' ',
// endText: '',
// }
],
}
</script>
子组件:
<template>
<!-- 设定一个容器,给一组id和高度当你使用这个组件。如果你想改变滚动条的样式,只改变.scrollContainer的风格在你的页面。-->
<div class="scrollContainer" :id="id" @mouseenter="monseenter" @mouseleave="mouseleave">
<slot></slot>
</div>
</template>
<script>
export default {
name: 'ScrollList',
props: {
id: String
},
data() {
return {
timer: null
};
},
methods: {
init() {
this.setTimer();
// this.$once代表只执行一次。如果组件是在keep-alive中包裹,则需要更换函数
// 被keep-alive包裹住的组件有两个生命周期函数:activated和deactivated
this.$once('hook:beforeDestroy', () => {
this.removeTimer();
});
},
removeTimer() {
if (this.timer) {
clearInterval(this.timer);
this.timer = null;
}
},
setTimer() {
this.removeTimer();
// 初始化容器尺寸
let scrollHeight = document.getElementById(this.id).scrollHeight;
let clientHeight = document.getElementById(this.id).clientHeight;
let heightDifference = scrollHeight - clientHeight;
// 开启滚动
if (heightDifference != 0) {
this.timer = setInterval(() => {
//像素高度 : 包括 el 和 填充 只读
let scrollHeight = document.getElementById(this.id).scrollHeight;
// 可见区域高度:包括el和填充只读
let clientHeight = document.getElementById(this.id).clientHeight;
let heightDifference = scrollHeight - clientHeight;
// 滚动高度:可读和可写的
document.getElementById(this.id).scrollTop++;
// 当滚动到顶部
if (document.getElementById(this.id).scrollTop >= heightDifference - 1) {
this.removeTimer();
// 让它回到原始位置后一秒
setTimeout(() => {
let id = document.getElementById(this.id)
if (id) {
document.getElementById(this.id).scrollTop = 0;
this.setTimer();
}
}, 1000);
}
}, 44);
}
},
monseenter() {
this.removeTimer();
},
mouseleave() {
this.setTimer();
}
},
mounted() {
this.init();
}
};
</script>
<style lang="scss" scoped>
// .scrollContainer::-webkit-scrollbar {
// width: 4px;
// background: aliceblue;
// }
.scrollContainer::-webkit-scrollbar-thumb {
background: palevioletred;
border-radius: 5px;
}
.scrollContainer {
height: 100%;
overflow: scroll;
overflow-x: hidden;
overflow-y: hidden;
}
// 兼容IE
// .scrollContainer {
// /*三角箭头的颜色*/
// scrollbar-arrow-color: #fff;
// /*滚动条滑块按钮的颜色*/
// scrollbar-face-color: #0099dd;
// /*滚动条整体颜色*/
// scrollbar-highlight-color: #0099dd;
// /*滚动条阴影*/
// scrollbar-shadow-color: #0099dd;
// /*滚动条轨道颜色*/
// scrollbar-track-color: #0066ff;
// /*滚动条3d亮色阴影边框的外观颜色——左边和上边的阴影色*/
// scrollbar-3dlight-color: #0099dd;
// /*滚动条3d暗色阴影边框的外观颜色——右边和下边的阴影色*/
// scrollbar-darkshadow-color: #0099dd;
// /*滚动条基准颜色*/
// scrollbar-base-color: #0099dd;
// }
</style>
结束
See the full FDA and EPA list here buy priligy online usa
Hi, for all time i used to check weblog posts here in the early hours in the break
of day, for the reason that i enjoy to gain knowledge of more and
more.
obviously like your web-site however you need to test the spelling on quite a few of your posts.
A number of them are rife with spelling issues and I to find it very troublesome to inform the truth however I will surely come back again.
This article is in fact a good one it assists new web visitors,
who are wishing in favor of blogging.
References:
Short term and long term effects of steroids
References:
http://72.60.136.153/@tbzmorris79099
References:
Best weight loss steroid
References:
http://techou.jp/index.php?bayshape7
References:
Cool cat casino
References:
https://brewwiki.win/wiki/Post:Instant_casino_Offizielle_Webseite_von_Casino_Instant_in_sterreich
References:
Rock steroids
References:
https://www.fcla.de/NEWS/index.php/;focus=STRATP_com_cm4all_wdn_Flatpress_38266970&path=&frame=STRATP_com_cm4all_wdn_Flatpress_38266970?x=entry:entry250102-115135%3Bcomments:1
References:
Buy best steroids
References:
https://lordhub.vip/gayreid6703017
References:
Steroid warehouse reviews
References:
https://cloudtu.be/@samualdownie3?page=about
References:
Steroids for muscle growth and fat loss
References:
http://47.98.161.246:3000/wilheminaflemi/wilhemina2005/wiki/Wirkstoff%3A-Clenbuterol-Unerw%C3%BCnschte-Wirkungen
References:
Testosterone a steroid
References:
https://git.miasma-os.com/winonastralia
References:
Anabolic steroid athletes
References:
https://txuki.duckdns.org/ollietrevizo04
References:
Anabolic steroid bodybuilding
References:
https://git.csi-kjsce.org/klarashah41860
References:
Steroids transformation
References:
https://www.findinall.com/profile/tod56k6287257
References:
Steroid cream withdrawal
References:
https://ex-pose.one/@lucienneqcx867?page=about
References:
Is winstrol a steroid
References:
https://simapodcast.co.ls/@shermanu75971?page=about
References:
Emotional effects of steroids
References:
http://106.55.0.66:31807/javierarcher7
References:
What kind of drug is steroids
References:
https://stelm.cfd/@thaliathorton8?page=about
Wonderful blog! I found it while searching on Yahoo News.
Do you have any suggestions on how to get listed in Yahoo News?
I’ve been trying for a while but I never seem to get there!
Thanks
References:
https://pad.stuve.de/s/d_YU0ZEOp
References:
Instant Casino Spiele
References:
https://cineblog01.rest/user/fearstool90/
References:
Instant Casino VIP Programm
References:
https://mmcon.sakura.ne.jp:443/mmwiki/index.php?cattleyoke51
References:
Instant Casino Bonus Code
References:
https://justbookmark.win/story.php?title=online-casino-mit-paypal-sicher-schnell-einzahlen-2026
References:
Instant Casino anmelden
References:
https://raymond-ismail-2.hubstack.net/willkommensbonus-200
References:
Body building hormones
References:
https://enregistre-le.space/item/482003
References:
Cheapest steroid cycle
References:
https://md.un-hack-bar.de/s/0ktg2HK2So
References:
Casinos tunica ms
References:
https://king-wifi.win/wiki/4000_Pokies_Live_Games_AUD_Bonuses
References:
Bodybuilders before steroids
References:
https://beshortlisted.com/employer/finding-the-best-anavar-across-the-modern-sports-pharmacology-market/
References:
What do medical steroids do to your body
References:
https://www.teacircle.co.in/klensmart-40mcg-clenbuterol-buy-cheap-price/
Hey there! I’ve been reading your blog for some time now and finally got the bravery to go ahead
and give you a shout out from New Caney Tx! Just wanted to say
keep up the fantastic work!
frank zane steroids
References:
https://helbo-hougaard-2.hubstack.net/how-to-get-a-trt-prescription-and-buy-testosterone-online
why are steroids illegal in the us
References:
https://dlx.hamdard.pk/user/profile/332749
legal medical uses for steroids
References:
https://noticias-sociales.site/item/595455
some studies have found a reduced risk for acne among people consuming
References:
https://scientific-programs.science/wiki/Testosterone_Replacement_Therapy
legal synthetic steroids
References:
https://algowiki.win/wiki/Post:Testosterone_Cypionate_Injection
References:
Echtgeld Casino Anbieter
References:
https://yogicentral.science/wiki/Online_Casino_Echtgeld_2026_Beste_Anbieter_im_Vergleich
truth about bodybuilding supplements
References:
https://hedgedoc.eclair.ec-lyon.fr/s/B0ISkEPBO
References:
Classy coin casino
References:
https://squareblogs.net/jamexpert3/beste-paypal-online-casinos-casinos-mit-paypal-einzahlung-2026
References:
Rocketplay casino neosurf promo code
References:
https://postheaven.net/shoeground6/rocketplay-neosurf-deposits-in-canada
References:
How to deposit with neosurf on rocketplay
References:
https://pads.jeito.nl/s/OQhXuJCxP2
References:
Dbol acne
References:
https://zenwriting.net/markmuscle60/acheter-testosterone-guide-et-prix-hl4j
References:
High stake slots online
References:
https://peatix.com/user/29378695/view
References:
Acheter testostérone en ligne
References:
https://mahmoud-svensson-2.blogbright.net/testost-c3-a9rone-en-france-guide-dachat
References:
The isle casino
References:
https://diplomatasnews.com.br/baianao/baiano-serie-a/fluminense-de-feira/novo-preparador-fisico-e-anunciado-pelo-fluminense-de-feira/
References:
https://graph.org/Level-Up-Your-Game-Top-Casino-Strategies-for-Winners-04-20 promotions and offers
References:
Roulette betting
References:
https://graph.org/Lucky-Green-Casino-Review-Slot-Games-and-Bonus-Guide-04-20
This is my first time visit at here and i am truly pleassant
to read everthing at alone place.
References:
Red dead redemption blackjack
References:
https://bad-oeynhausen-casino-poker.online-spielhallen.de/
References:
Wolfsburg
References:
https://paysafe-casino-bonus.online-spielhallen.de/
References:
Paderborn
References:
https://casino-montreux-switzerland.online-spielhallen.de/
References:
Cologne (Köln)
References:
https://eternal-slots-casino-no-deposit-bonus-codes.online-spielhallen.de/
References:
Dortmund
References:
https://pinko-casino.online-spielhallen.de/
References:
Mahjong more time
References:
https://graph.org/Zoome-Casino-No-Deposit-Bonus-04-27
Right here is the right webpage for anybody who really wants to find out about this topic.
You realize so much its almost hard to argue with you (not that I really will
need to…HaHa). You definitely put a fresh spin on a subject that has been discussed for ages.
Great stuff, just excellent!
References:
Hvad betyder høj udbetaling på casino
References:
https://fanajobs.com/profile/isiahperez1195
References:
Casinoer med flest udbetalinger
References:
http://881.cz/home.php?mod=space&uid=302150
References:
Bedste casinoer i Danmark til udbetaling
References:
https://cyprusjobs.com.cy/companies/online-slots-mit-hoher-rtp-de-%EF%B8%8F-2025/
Hey would you mind letting me know which hosting company you’re
utilizing? I’ve loaded your blog in 3 completely different internet browsers and I must say this
blog loads a lot faster then most. Can you recommend a good hosting
provider at a reasonable price? Kudos, I appreciate it!
Hey would you mind letting me know which webhost you’re utilizing?
I’ve loaded your blog in 3 completely different internet browsers and I must say this blog loads a lot faster then most.
Can you suggest a good web hosting provider at a fair price?
Thank you, I appreciate it!
Любителям активного отдыха точно понравится возможность увидеть Кавказ и попробовать себя в настоящем восхождении.
Организаторы предлагают разные маршруты восхождения, сопровождение гидов и помощь с подготовкой к путешествию.
На сайте https://www.elbrustours.ru можно подробно изучить маршруты, даты туров и условия участия.
Судя по комментариям участников, такие туры оставляют действительно яркие впечатления и помогают увидеть невероятные горные пейзажи Кавказа.
References:
Cairns casino https://git.hanumanit.co.th/clclatasha1221
References:
Slot play https://www.fightdynasty.com/companies/microgaming-casinos-bonuses-rated-listed%E3%80%902026%E3%80%91/
References:
Casino pauma https://bwjobs4graduates.online/companies/best-microgaming-online-casinos-2026-microgaming-slots-guide/
References:
Valley view casino center san diego https://feleempleo.es/employer/microgaming-online-casinos-2026-play-microgaming-slots-for-free/
References:
Blackjack regler https://cchkuwait.com/employer/fruit-fiesta-demo-slot-play-for-free/
References:
Vicksburg casinos https://bluestreammarketing.com.co/employer/book-of-oz-slot-review/
References:
Las vegas slot machines https://mobidesign.us/employer/microgaming-demo-slots