根据24小时刻度线将工作时段进行表示展示

实现出发点,即利用组件的进度条,将24段div包裹的进度条组装成一个完整刻度线(生成一个组件,通过for循环遍历出来)
实现效果图:
在这里插入图片描述
实现代码,封装内部组件timebar.vue

<template>
    <div>   
        <span >{{time}}</span>
        <div class="bar">
        <q-linear-progress  size="10px"  :value="progress" />
        </div>
    </div>    
</template>

<script>
export default {
    props:{
        time:{type:Number},
       
    },
    data() {
        return {
            progress: 0,
        }
    },

    methods: {
        setFull(){
            this.progress = 1;
        },
    },
}
</script>
<style lang="scss" scoped>
    .bar{
        width:30px;
        height: 10px;
        border-right: 1px solid black;
        margin-top:4px;
    }
</style>

在父组件中定义组件名称,并for循环处对应的效果:

<q-card-section class="q-pt-none">
 <div class="container" v-for="(item,index) in validTimeList" :key="index"  >
    <div style="marginTop:18px;marginRight:18px;width:16%">{{item.date_s.substring(0,10)}}<span style="marginLeft:16px;">{{item.day_time}}</span></div>
    <div v-for="(item,tkey) in 24" :key="tkey">
      <Timebar :ref="`bar_${index}_${tkey+1}`" :time="tkey+1"  />
    </div>
  </div>
</q-card-section>

后端返回的vaildTimeList的数据的格式如下图所示:
在这里插入图片描述
ref的值进行双重组合命名为保证名称不重复,在v-for循环下的ref类型会被转化为数组形式,因此取值的时候需要通过[0]进行精确取值;

js取值代码实现功能:

this.validTimeList.forEach((item,index)=>{
    if(item.time.length == 0){
      return 
    }else {
      item.time.forEach(items=>{
        this.$nextTick(()=>{
            this.$refs[`bar_${index}_${items.hour}`][0].setFull();
        })
      })
    }
  })
  • 使用vue中的nextTick的主要解决获取不到dom的报错;
GitHub 加速计划 / vu / vue
82
16
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:4 个月前 )
9e887079 [skip ci] 3 个月前
73486cb5 * chore: fix link broken Signed-off-by: snoppy <michaleli@foxmail.com> * Update packages/template-compiler/README.md [skip ci] --------- Signed-off-by: snoppy <michaleli@foxmail.com> Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 6 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐