鸽了这么久,一晃2个月过去了。自考+上班没时间记录。

前不久看到移动官网上的时间轴效果,看起来不错,我也来试着做一下。

需要元素滚动到视野内加载动画。

插件地址 https://ext.dcloud.net.cn/plugin?id=906

uniapp不能操作dom,写这个还是思考了很久。效果如下

一、布局

画主轴。内容分割成块,当出现在视野中(滚动监听),加载载入动画。

内容块中分别有一个圆点、详情内容。

<!-- 时间轴 css就不贴出来了-->
<view class="time-line-container" :class="addTypeClass">
<!-- 时间轴内容块列表 -->
<view class="time-line-list"> <!-- 时间轴内容块 绑定id值-->
<view class="time-line-info" :key="index" :class="[layoutClass(index)]" :id="'timeline'+index" v-for="(item,index) of time_line_list"> <!-- 内容块内容 -->
<view class="line-info-content" > <!-- 时间轴圆点 -->
<view class="line-on-round" :style="{ opacity: current[index]&&current[index].is=='ok'?1:0,top:'50px'}" :class="current[index]&&current[index].is=='ok'?comeani:''"></view>
<!-- 内容 -->
<view class="info-content-wrap" :style="{ opacity: current[index]&&current[index].is=='ok'?1:0}" :class="current[index]&&current[index].is=='ok'?comeani:''">
<!-- 标题 -->
<view class="info-title">
{{item.title}}<span>{{item.title_span}}</span>
</view> <!-- 内容 -->
<view class="info-content">
<!-- 内容 -->
<view class="info-txt">{{item.content}}</view>
</view>
</view> </view>
</view>
</view>
</view>

二、js

首次进入页面,需获取屏幕高度,初始化一个current,开始获取每个元素的位置信息。

          init(){
try {
// 获取屏幕高度
const res = uni.getSystemInfoSync();
this.HEIGHT=res.screenHeight;
// 添加标志位
for(let i=0;i<this.time_line_list.length;i++){
this.current.push({tag:'timeline'+i,is:'no'});
}
// 开始获取位置信息
this.getScroll();
} catch (e) {
// error
}
},

循环一下所有的元素并获取每个元素的位置信息,得到后加入数组

        async getScroll(){
if(!this.isScroll){return;}
let info=[];
// 返回位置信息加入数组 等待获取完成再进行loadani操作
for(let i=0;i<this.time_line_list.length;i++){
await this.getNodeList('timeline'+i,i).then(res => {
info.push(res);
});
}
this.result.push({info:info});
// 加载动画
this.loadani();
},
       getNodeList(id,i){
// 获取位置信息并返回
return new Promise(resolve=>{
const query = uni.createSelectorQuery().in(this);
query.select('#'+id).boundingClientRect(data => {
// console.log("得到布局位置信息" + JSON.stringify(data));
// console.log("节点离页面顶部的距离为" + data.top);
resolve({domInfo:data.height,domTop:data.top,tag:id})
}).exec();
});
},

获取到距离顶部的距离就可以判断是否出现在视野内,并把标志位设置为相应状态

       loadani(){
for(let i=0;i<this.result.length;i++){
for(let j=0;j<this.result[i].info.length;j++){
// 是否没加载动画
if(this.current[j].is!='ok'){
// 是否进入视野
if(this.current[j].tag==this.result[i].info[j].tag &&
this.result[i].info[j].domTop+90<this.HEIGHT){
// 加载动画
this.current[j].is='ok';
this.sum=j+1;
}
}
}
// 移除当前
this.result.splice(i,1);
}
// 是否全部加载完成
if(this.sum==this.time_line_list.length){this.isScroll=false;}
},

在主界面,还要监听每次的滚动,看元素是否滚动到视野内了

组件引入:

<time-line ref="timeline" location="center" title="我的时间轴"></time-line>

     onPageScroll() {
this.$refs.timeline.getScroll();
},

这样就完成了,写的有点繁琐哈哈。省略部分内容,可以看完整示例。

附上GitHub地址:https://github.com/steffenx/timeLine-uniapp.git

uniapp滚动监听元素的更多相关文章

  1. Bootstrap 下拉菜单和滚动监听插件

    一.下拉菜单 常规使用中,和组件方法一样,代码如下: //声明式用法 <div class="dropdown"> <button class="btn ...

  2. bootstap 滚动监听

    ---首先结合源代码介绍官网的说明 ---然后总结了使用滚动监听的几个步骤 ---最后给出一个简单的例子 ---关键的一点:整体有点零散和乱七八糟,辛苦你的思维和眼睛了,呵呵 ------------ ...

  3. bootstrap-js(3)滚动监听

    导航条实例 ScrollSpy插件根据滚动的位置自动更新导航条中相应的导航项. 拖动下面区域的滚动条,使其低于导航条的位置,注意观察active类的变化.下拉菜单中的子项也会跟着变为高亮状态. 1.调 ...

  4. Bootstrap入门(二十六)JS插件3:滚动监听

    很多时候我们在浏览一些网页的时候,导航条会根据我们浏览网页的进度而发生不同的变化,这种就是滚动监听. 你的顶栏导航,添加data-spy="scroll"到您想要刺探(最典型的是这 ...

  5. better-scroll不能滚动之 滚动监听-左右联动

    滚动监听 better-scroll 无法滚动的分析,直接翻到最后,看问题汇总,希望能帮助你解决. 借用一下人家这个好看的项目图片,做一个解释.左边的内容会跟右边的内容一起关联,点击左边的菜单,右边会 ...

  6. amaze ui 滚动监听

    引入   此框架的css  js    前提还要有jquery http://amazeui.org/javascript/scrollspy 然后看这个链接里的各种动画 运用方法就是  在你想要有动 ...

  7. bootstrap源码之滚动监听组件scrollspy.js详解

    其实滚动监听使用的情况还是很多的,比如导航居于右侧,当主题内容滚动某一块的时候,右侧导航对应的要高亮. 实现功能 1.当滚动区域内设置的hashkey距离顶点到有效位置时,就关联设置其导航上的指定项 ...

  8. jQuery实现滚动监听

    1.设计思路 1)获取窗口滚动高度: 2)获取附加导航栏: 3)获取导航栏下的所有li: 4)通过相同class获取所有监听元素:(此例中为jumbotron巨幕) 5)遍历所有监听元素,若当前元素距 ...

  9. Bootstrap学习js插件篇之滚动监听

    1.滚动监听 案例 滚动监听插件可以根据滚动条的位置自动更新所对应的导航标记.Bootstrap中文网左侧就是一个滚动监听的例子. 代码段: <nav id="navbar-examp ...

随机推荐

  1. 【Java】 语言基础习题汇总 [2] 面向对象

    30 面向对象的三条主线和面向对象的编程思想? 类与类的成员 : 属性.方法.构造器.代码块.内部类. 面向对象的三大特征:封装.继承.多态[如果还有一个,那就是抽象] 关键字:this.super. ...

  2. Linux常用命令01(文件和目录)

    目标 查看目录内容 ls 切换目录 cd 创建和删除文件 touch rm mkdir 拷贝和移动文件 cp mv 查看文件内容 cat more grep 其他 echo 重定向 > 和 &g ...

  3. Docker安装Redis并介绍漂亮的可视化客户端进行操作

    1 简介 Redis是使用ANSI C语言开发的基于Key-Value的高性能NoSQL数据库,在解决高并发.高可用等一系列问题中,它扮演着重要的角色.它的优势主要有: 速度快. 持久化. 原子性. ...

  4. 计算机系统基础学习笔记(1)-基本GCC,objdump,GBD命令的使用

    基本GCC命令的使用 GCC是一套由GNU项目开发的编程语言编译器,可处理C语言. C++.Fortran.Pascal.Objective-C.Java等等.GCC通常是 跨平台软件的编译器首选.g ...

  5. Java读源码之CountDownLatch

    前言 相信大家都挺熟悉 CountDownLatch 的,顾名思义就是一个栅栏,其主要作用是多线程环境下,让多个线程在栅栏门口等待,所有线程到齐后,栅栏打开程序继续执行. 案例 用一个最简单的案例引出 ...

  6. iview使用之怎样给Page组件添加跳转按钮

    在项目开发过程中,我们会经常遇到使用分页的表格,然而在ivieiw中,我们通常只能使用Page组件自带的功能,如下图: 切换每页条数这些基本的功能都不说了,有时候我们需要在输入框里输入想要跳转到的页数 ...

  7. 硬盘性能测试工具之bonnie++

    bonnie++ 官方站点 先写内存的两倍,内存较大时比较耗时.适合简单的测试场景. # bonnie++ -u root 写测试 读测试 Version 1.97 ------Sequential ...

  8. 高德局部刷新标记点,bug解决

    将接口返回的经纬集合点在高德地图上标记展示, 如果实时刷新地图标记点,不加优化,则会造成过多的带宽消耗 所以,地图只需加载一次,局部更新标记点就好了 代码: <template> < ...

  9. windows下部署.netcore+docker系列一(安装linux (ubuntu18.4))

    1 下载 虚拟机和 linux 系统 版本是 ubuntu 链接:https://pan.baidu.com/s/1jTxdysoyOhSWD-Ea-7JIbg 提取码:iiad 2  首先要安装 虚 ...

  10. scrapy爬虫实例(1)

    爬虫实例 对象 阳光问政平台 目标 : 主题,时间,内容 爬取思路 预先设置好items import scrapy class SuperspiderItem(scrapy.Item): title ...