资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

兄弟组件之间联动--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://cdkjz.cn/article/gsspjs.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

业务热线:400-028-6601 / 大客户专线   成都:13518219792   座机:028-86922220