微信小程序实现锚点定位楼层跳跃的实例
作者:Rolan 发布时间:2024-08-22 12:44:42
标签:微信,小程序,锚点定位
微信小程序实现楼层锚点跳跃,点击不同的锚点进行位置跳跃:
利用:scroll-into-view 来实现
效果图如下:
WXML:
<scroll-view class="content" scroll-into-view="{{toView}}" scroll-y="true" scroll-with-animation="true">
<view wx:for="{{act_addList}}">
<view class="address_top" id="{{ 'inToView'+item.id}}">{{item.region}}</view>
<view wx:for="{{item.city}}">
<view class="address_bottom">{{item.name}}</view>
</view>
</view>
</scroll-view>
<view class="orientation_region">
<view class="orientation">自动定位</view>
<block wx:for="{{orientationList}}" >
<view class="orientation_city" bindtap="scrollToViewFn" data-id="{{item.id}}">{{item.region}}</view>
</block>
</view>
WXSS:
page{ height: 100%;}
.content{padding-bottom: 20rpx; box-sizing: border-box; height: 100%;}
.location{width: 100%;}
.location_top{height: 76rpx;line-height: 76rpx; background: #f4f4f4;color: #606660;font-size: 28rpx;padding: 0 20rpx;}
.location_bottom{height: 140rpx;line-height: 140rpx;color: #d91f16;font-size: 28rpx;border-top: 2rpx #ebebeb solid; border-bottom: 2rpx #ebebeb solid;padding: 0 20rpx; align-items: center;display: -webkit-flex;}
.address_top{height: 76rpx;line-height: 76rpx; background: #f4f4f4;color: #999999;font-size: 28rpx;padding: 0 20rpx;}
.address_bottom{height: 88rpx;line-height: 88rpx; background: #fff;color: #000000;font-size: 32rpx;padding: 0 20rpx; border-bottom: 2rpx #ebebeb solid;margin-left: 20rpx;margin-right: 50rpx; }
.location_img{width: 48rpx;height: 48rpx;position: absolute;right: 20rpx;top: 125rpx;}
.add_city{width: 228rpx;height: 60rpx;line-height: 60rpx; text-align: center; border: 2rpx solid #ebebeb; color: #000000;margin-right: 20rpx; }
.add_citying{width: 228rpx;height: 60rpx;line-height: 60rpx; text-align: center; border: 2rpx solid #09bb07; color: #09bb07;margin-right: 20rpx;}
.orientation{white-space:normal;display: inline-block; width: 55rpx;height:58rpx; color: #999; text-align: center;}
.orientation_region{ width: 55rpx;font-size: 20rpx;position: fixed;top: 220rpx; right: 0rpx;}
.orientation_city{height: 50rpx; line-height: 50rpx;color: #000;text-align: center;}
JS:
Page({
/**
* 页面的初始数据
*/
data: {
orientationList: [
{ id: "01", region: "东北" },
{ id: "02", region: "华北" },
{ id: "03", region: "华东" },
{ id: "04", region: "华南" },
{ id: "05", region: "华中" },
{ id: "06", region: "西北" },
{ id: "07", region: "西南" }
],
act_addList: [
{
id: "01", region: "东北地区",
city: [{ id: "0101", name: "白山江源" },
{ id: "0102", name: "白山市" },
{ id: "0103", name: "宾县" },
{ id: "0104", name: "大庆" },
{ id: "0105", name: "测试1" },
{ id: "0106", name: "测试2" },
{ id: "0107", name: "测试3" },
{ id: "0108", name: "测试4" },
{ id: "0109", name: "测试5" },
{ id: "0110", name: "测试6" },
]
},
{
id: "02", region: "华北地区",
city: [{ id: "0201", name: "包头" },
{ id: "0202", name: "保定" },
{ id: "0206", name: "测试2" },
{ id: "0207", name: "测试3" },
{ id: "0208", name: "测试4" },
{ id: "0209", name: "测试5" },
{ id: "0210", name: "测试6" },
]
},
{
id: "03", region: "华东地区",
city: [{ id: "0303", name: "开封市" },
{ id: "3104", name: "安阳市" },]
},
{
id: "04", region: "华南地区",
city: [
{ id: "0401", name: "黑龙江市" },
{ id: "0407", name: "测试3" },
{ id: "0508", name: "测试4" },
{ id: "0609", name: "测试5" },
{ id: "0710", name: "测试6" },
{ id: "0711", name: "测试8" },
{ id: "0712", name: "测试9" },
{ id: "0713", name: "测试10" },
{ id: "0714", name: "测试11" },
]
},
{ id: "05", region: "华中地区", city: [{ id: "0501", name: "黑龙江市" }] },
{
id: "06", region: "西北地区",
city: [{ id: "0603", name: "开封市" },
{ id: "0604", name: "安阳市" },]
},
{
id: "07", region: "西南地区",
city: [{ id: "0703", name: "开封市" },
{ id: "0704", name: "安阳市" },
{ id: "0401", name: "黑龙江市" },
{ id: "0407", name: "测试3" },
{ id: "0508", name: "测试4" },
{ id: "0609", name: "测试5" },
{ id: "0710", name: "测试6" },
{ id: "0711", name: "测试8" },
{ id: "0712", name: "测试9" },
{ id: "0713", name: "测试10" },
{ id: "0714", name: "测试11" },
{ id: "0401", name: "黑龙江市" },
{ id: "0407", name: "测试3" },
{ id: "0508", name: "测试4" },
{ id: "0609", name: "测试5" },
{ id: "0710", name: "测试6" },
{ id: "0711", name: "测试8" },
{ id: "0712", name: "测试9" },
{ id: "0713", name: "测试10" },
{ id: "0714", name: "测试11" },
]
},
],
toView: 'inToView01',
},
scrollToViewFn: function (e) {
var _id = e.target.dataset.id;
this.setData({
toView: 'inToView' + _id
})
console.log(this.data.toView)
},
onLoad: function (options) {
}
})
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://www.wxapp-union.com/article-2298-1.html


猜你喜欢
- #!#backup.sh##系统名称sysname=gzsyspath=/home/oracle/databak/$sysname/v_da
- 最近小菜鸟看了妙味课堂的js视频,学习了一点知识,在这里总结一下,代码写的有点臃肿,刚开始学,不知道咋着优化,看到的高手可以指点一下,呵呵,
- 因此,在数据库的日常维护工作中,如果只是一次两次碰到ORA-01555错误,一般都先忽略,但是如果经常碰到该错误,则要进行一些调整以避免该错
- 由于实际需要,简要写了个小脚本,并打包生成exe,供无网络环境下使用脚本1:显示当前时间与时间戳,以及10分钟后的时间与时间戳# -*- c
- 在收发快递填写地址的时候,我们会经常手动输入地址让程序智能识别,标准的地址比如,xx省xx市xx县/区xx路xx号,不过有时候也可以简单写:
- 下面是列表合并的4种方法,其中的代码都在Python3下测试通过,在Python2下运行应该也没问题,时间关系就没测试,遇到问题可以联系小编
- 1、异常出现的场景.:在使用Hibernate做为项目持久层的情况下,需要对某一张表进行一个扩展,扩展操作便是在该表上创建一个触发器。将表中
- 属性多层数组数据的添加修改为什么需要使用Vue.set?vue中不能检测到数组的一些变化比如一下两种:1、数组长度的变化 vm.arr.le
- 使用MySql的窗口函数统计数据时,发现一个小的问题,与大家一起探讨下。环境配置:mysql-installer-community-8.0
- python的百分号输出比较奇怪,代码如下print('%s%%'%(5))#这样就能输出‘5%'来源:https:
- 本文实例讲述了Python排序搜索基本算法之选择排序。分享给大家供大家参考,具体如下:选择排序就是第n次把序列中最小的元素排在第n的位置上,
- AJAX:Asynchronous JavaScript And XML--------异步JavaScript和XML
- 1、简介pyqt 列表 单元格中 不仅可以添加数据,还可以添加控件。我们尝试添加下拉列表、一个按钮试试。setItem:将文本放到单元格中s
- 1,执行SQL查看select @@session.sql_mode;全局级别: 查看select @@global.sql_mode;2,
- blur事件在元素失去焦点时触发。在一些jquery的教程、api手册等上面对blur事件,提供了一个错误的例子,就是关于p标签失去焦点的问
- 模块的相关概念 1. 什么是模块模块就好比是工具包,要想使用这个工具包中的工具(就好比函数),就需要导入这个模块模块的英文名叫:
- 介绍当在图像上训练深度神经网络模型时,通过对由数据增强生成的更多图像进行训练,可以使模型更好地泛化。常用的增强包括水平和垂直翻转/移位、以一
- 区别与联系: 1、get是从服务器上获取数据,post则是向服务器传送数据; 2、get将表单中数据的按照variable=value的 形
- 首先是最常规的方法: <p>test</p> <script> function test(){ ale
- asp vbs Cache缓存类属性valid,是否可用,取值前判断属性name,cache名,新建对象后赋值方法add(值,到期时间),设