vue 城市列表与字母表联动
实现两个联动
一是点击右侧字母的时候,城市列表出现相应首字母下的城市
二是鼠标在字母表上滑动的时候,城市列表实时跟着变化

一.点击字母出现相应的列表,给每个字母设置handleLetterClick事件
- <template>
- <div>
- <ul class="list">
- <li class="item"
- v-for="item of letters"
- :key="item"
- @click="handleLetterClick"
- @touchstart="handleTouchStart"
- @touchmove="handleTouchMove"
- @touchend="handleTouchEnd"
- :ref="item"
- >
- {{item}}
- </li>
- </ul>
- </div>
- </template>
获取当前点击的字母,传给父组件city,再由city组件传给城市列表list组件,再根据字母滚动到相应的内容
- <city-alphabet :cities="cities" @change="handleLetterChange"></city-alphabet>
- handleLetterChange(letter){
- this.letter=letter
- }
城市列表list组件获取到父组件传过来的letter,并监听letter的变化
- props:{
- hot:Array,
- cities:Object,
- letter:String
- },
- watch:{
- //监听letter,当letter发生变化时触发
- letter(){
- if(this.letter){
- const element=this.$refs[this.letter][0]
- this.scroll.scrollToElement(element)
- }
- }
- }
二.当鼠标滑动的时候,城市列表实时地发生变化
实现原理:其实和点击的时候一样,当鼠标滑动时,实时地获取滑动的时候所经过的字母,再把字母传给城市列表list组件,再跳转到相应的元素
((鼠标距顶部的距离一79)一A字母距父元素的距离)/每个字母的高度20 计算此时鼠标所在的第几个字母
- <template>
- <div>
- <ul class="list">
- <li class="item"
- v-for="item of letters"
- :key="item"
- @click="handleLetterClick"
- @touchstart="handleTouchStart"
- @touchmove="handleTouchMove"
- @touchend="handleTouchEnd"
- :ref="item"
- >
- {{item}}
- </li>
- </ul>
- </div>
- </template>
- <script>
- export default {
- name:"CityAlphabet",
- data (){
- return{
- touchStatus:false,
- startY:0,
- //函数截流,提高性能
- timer:null
- }
- },
- updated(){
- //A字母元素到父元素顶部的距离
- this.startY=this.$refs["A"][0].offsetTop
- },
- props:{
- cities:Object
- },
- computed: {
- letters () {
- const letters = []
- for (let i in this.cities) {
- letters.push(i)
- }
- return letters
- }
- },
- methods:{
- handleLetterClick(e){
- //把字母传给父亲,父亲再给List
- //e.target.innerText获取里边的内容
- this.$emit('change',e.target.innerText)
- },
- handleTouchStart(){
- this.touchStatus=true
- },
- handleTouchMove(e){
- if(this.touchStatus){
- if(this.timer){
- clearTimeout(this.timer)
- }
- this.timer=setTimeout(() => {
- //touchstart事件:当手指触摸屏幕时候触发,即使已经有一个手指放在屏幕上也会触发。
- //touchmove事件:当手指在屏幕上滑动的时候连续地触发。在这个事件发生期间,调用preventDefault()事件可以阻止滚动。
- //touchend事件:当手指从屏幕上离开的时候触发。
- //touches:表示当前跟踪的触摸操作的touch对象的数组。
- //clientY:触摸目标在视口中的y坐标。
- //79是绿色底部到顶部的距离
- const touchY=e.touches[0].clientY-79
- //每个字母的高度是20
- const index=Math.floor((touchY-this.startY) / 20)
- console.log(touchY)
- if(index >= 0&&index < this.letters.length){
- this.$emit('change',this.letters[index])
- }
- }, 16);
- }
- },
- handleTouchEnd(){
- this.touchStatus=false
- }
- }
- }
- </script>
vue 城市列表与字母表联动的更多相关文章
- Vue2.5开发去哪儿网App 城市列表开发之 兄弟组件间联动及列表性能优化
一, 兄弟组件间联动 1. 点击城市字母,左侧对应显示 给遍历的 字母 添加一个点击事件: Alphabet.vue @click="handleLetterClick" ha ...
- vue实现城市列表选择
成果展示 最后的成果就是下面所展示的内容,因为gif图没有做,只能截图所展示,接下来,会带着大家一步一步的完成下面功能,脚手架搭建和node安装在本次案例不会讲解,如果了解,可以在我的博客园找到有详细 ...
- 基于MVC4+EasyUI的Web开发框架经验总结(7)--实现省份、城市、行政区三者联动
为了提高客户体验和进行一些技术探索,现在正准备把我自己的客户关系管理系统CRM在做一个Web的版本,因此对基于MVC的Web界面继续进行一些研究和优化,力求在功能和界面上保持和Winform一致,本文 ...
- vue-cli 3.0 实现A-Z字母滑动选择城市列表
项目地址: https://github.com/caochangkui/vue-cli3 项目代码: 城市列表首页: City.vue <template> <div id=&qu ...
- 用vue实现省市县三级联动
我真的没想到这个会困扰到我.最开始以为,不就是直接找个简单的插件就实现了吗,jquery插件找了几个,都没有达到目的. 需求是这样的: 点击input框,弹出一个popup,然后可以滚动选择省,市,县 ...
- vue移动端地址三级联动组件(一)
vue移动端地区三级联动 省,市,县.用的vue+mintUi 因为多级联动以及地区的规则比较多.正好有时间自己写了一个.有问题以及建议欢迎指出.涉及到dom移动,所以依赖vue+jquery.这边数 ...
- (转)基于MVC4+EasyUI的Web开发框架经验总结(7)--实现省份、城市、行政区三者联动
http://www.cnblogs.com/wuhuacong/p/3841338.html 为了提高客户体验和进行一些技术探索,现在正准备把我自己的客户关系管理系统CRM在做一个Web的版本,因此 ...
- Android例子源码非第三方实现根据字母排序的城市列表
values 下dimens.xml <resources> <!-- Default screen margins, per the Android Design guidelin ...
- 获取中央气象台API 完整城市列表简单方式
activity_main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android& ...
随机推荐
- 远程调用历史及代码编写demo
历史介绍部分: 远程调用大致经过了corba.webservice.二进制跟restful四个阶段 corba时代,corba(Common Object Request Broker Archite ...
- Spring Boot(一)Hello World
Spring Boot适合与微服务,方便快速开发,简化配置(约定>配置). 准备工作: SpringBoot 2.0 jdk8 IDEA或者eclipse+Spring Tool Suits 创 ...
- DEDE把变量放进session中,结果取值为null的问题
最近在基于织梦CMS(dedecms)做公司网站,可以说改动不少,而其中最令我印象深刻的就是织梦的session. 自己想在前台页面限制一些用户的访问,且后台用户可以访问.必须验证织梦后台用户的 ...
- ubuntu 下安装配置LAMP
详情见: http://www.linuxeden.com/html/softuse/20130731/141934.html
- 斗鱼扩展--notifications提示(十二)
来说下 桌面通知 Notification,HTML5支持 Web Notifications 的实例,但是要经过用户允许, chrome://settings/content/notificati ...
- Java入门之Tomcat安装及环境变量配置
一.Tomcat下载 地址:http://tomcat.apache.org/download-80.cgi#8.0.39 本人用的是Tomcat/8.0.37免安装版,解压到一个目录,本人用的是:D ...
- 【转】js弹出框、对话框、提示框、弹窗总结
js弹出框.对话框.提示框.弹窗总结 一.js的三种最常见的对话框 //====================== JS最常用三种弹出对话框 ======================== //弹 ...
- ora-12541:tns: 无监听程序解决办法
1.首先找到 Oracle 安装文件 中 listener.ora文件与tnsnames.ora文件: 列如:路径:E:\app\当前系统的账户名\product\11.2.0\dbhome_1\NE ...
- Redis入门--(二)Redis的概述
1.Redis的由来 创始人觉得Mysql不好用,就自己写了: 国内使用Redis的网站有新浪微博,知乎: 国外GitHub: VMWare也支持redis的开发 2.Redis的概述 官方提供的测试 ...
- Android 开发知识结构图