网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

兄弟组件之间联动--vue开发app点击字母展示地区列表

兄弟组件之间联动--vue开发app点击字母展示地区列表

创新互联专注于成都做网站、网站建设、外贸营销网站建设、网页设计、网站制作、网站开发。公司秉持“客户至上,用心服务”的宗旨,从客户的利益和观点出发,让客户在网络营销中找到自己的驻足之地。尊重和关怀每一位客户,用严谨的态度对待客户,用专业的服务创造价值,成为客户值得信赖的朋友,为客户解除后顾之忧。

下图这种地区搜索方式在很多app中都很常见,今天就使用vue框架中的 better-scroll 第三方包来实现页面滚动和点击侧边栏字母该字母开头的地区列表置顶功能。

来源:凯哥Java(kaigejava)

兄弟组件之间联动--vue开发app点击字母展示地区列表

1、A子组件通过使用 this.$emit(事件名字,事件携带内容) 向外触发事件

首先,在组件每个字母元素上绑定事件,在该事件中向外触发事件,并将值传递出去:

methods:{

    handleLetterClick(e){

        this.$emit('change',e.target.innerText)

    }

}

2、父组件接收A组件传过来的事件,并通过属性来向B组件传值

因为组件传递过来的是单个字符串,所以,先在data中定义一个属性letter来接收这个值;

联系凯哥-》凯哥Java(kaigejava)

或凯哥个人博客:www.kaigejava.com

悄悄说下,凯哥个人博客可以私信凯哥哦~

并在父组件模板中的组件中定义传递的方法@change="handleLetterChange"用来获取传递的值;

将letter属性传递给另一个子组件

data(){

    return{

        letter:''

    }

},

methods:{

    handleLetterChange(letter){

        this.letter = letter

    }

},

3、B组件接收父组件传递过来的属性,并通过watch监听参数的变化,然后执行页面的滚动显示

首先,给每个地址列表区域元素加 ref ,better-scroll会根据ref给指定区域进行操作;

然后使用watch监听letter变化,并使用better-scroll中的scrollToElement接口执行页面滚动;

v-for="(item,key) in city" 

:key="key"

:ref="key"

>

    ...

props:{

    letter:String

},

watch:{

    letter(){

        if(this.letter){

            // scrollToElement里只接受单个DOM元素,不接收数组

            //因为上面的div元素是数组渲染出来的,所以这里this.$refs得到的是数组

            const element = this.$refs[this.letter][0]

            this.scroll.scrollToElement(element)

        }

    }

}



文章名称:兄弟组件之间联动--vue开发app点击字母展示地区列表
网页路径:http://bjjierui.cn/article/gsspjs.html

其他资讯