Vue3 你可能忽略的 v-model 用法(一)

简介: Vue3 你可能忽略的 v-model 用法

image.png

Vue3 你可能忽略的 v-model 的巧用


前言:目前已经使用 Vue3 开发已经四个多月了,常用的一些机制自己确信已经玩的很明白了,但是在这周里看到同事的一个组件设计,用到了 V-model这个机制,给我一种恍然大悟,相见恨晚的感觉,为什么自己之前没早点了解到还可以这样用...

感觉自己忽略了 Vue 官方文档的很重要一些知识,于是重新对着官方文档大致看了一遍。 特来分享一下自己学习到的新的知识。

本文新手向,并不是单纯讲解用法,所以我不会直接就开始讲 v-model 的用法,接下来我会把我在项目中最真实的思路过程讲述出来,可能附加内容有点多。如果你只想看到 v-model 的用法,请直接跳转到《标题四

一. 需求背景


我们公司主要项目是移动端开发,使用移动端框架是 ionic-Vue。做过移动端开发的应该都知道,移动端页面的 Header(手机顶部) ,Content(内容区域),和Footer 都是非常固定的结构。大致结构基本上和微信这样的布局结构十分相似。这里相似是指的这三个部分的高度是不会轻易调整的,不然就会造成页面切换的时候页面整体因为高度的变化而造成的“抖动”。用户体验就会变得非常不舒服,这是我们需要避免的情况。

image.png

周四我在写 UI 提供的一个稿子的时候。简单来说需求就是类似于 QQ 界面的右上角的加号,然后出来一个小弹窗的效果。如下图所示:

image.png

二. 实现思路


由于这个“加号➕”是位于 Header 部分的,但是显示区域位于 Content 区域。最一开始的想法就是将这个弹窗部分使用绝对定位来实现,使它和 “加号➕” 位于同一个组件。很遗憾的是,Ionic 所封装的 Header 组件的高度是写死的,如果把这个弹出框写在和 <Ionic-Header>组件里的话就会出现如下的效果。

image.png

上图是我理想达到的效果(这里是为了方便演示,故意超出了一部分)

然而结果却是这样的。

image.png

由于 <ion-Header> 高度固定,并且设定了 overflow-hidden 属性,那么你的选项框是无法显示在 Header 部分的。并且其实这个设计思路在最开始就是错的,这个弹出框位于的区域就应该是 Content 区域,而就不应该是位于在 Header 里的。
tips: 在这里想给和我一样的新手开发者说一句,拿到需求切忌马上敲代码而忽略组件设计思路的思考

于是转变了想法,采用 React 状态提升的思路。将 HeaderContent 一起装在了同一个父亲组件里,将弹窗部分写在父组件里,并由父组件来提供改变状态的方法。
于是我的代码由下图的设计思路:

image.png

转变为了:

image.png

这里稍等一下,由于我们的 header 是一个通用的组件,所以它在实际项目中会是一个单独的通用组件的形式,这里我们把它抽离出去。所以项目的结构大概是这样样子的。

image.png

这里稍微调整一下样式,如下所示:(这里解释一下,这里使用的是 tailwindCss 使用自己的语法将样式样式内嵌在 class 属性内,和传统写在 style 里没任何区别)

image.png

5.这时候就很简单了,我设定一个属性值,在点击按钮的时候弹出选项框,再次点击按钮,关闭选项框即可。默认状态下为关闭即可。

image.png

三. 使用 Props 的方法


接下来就得想办法将这个属性传递给 <Header/> 组件了。非常简单,我们直接使用 props 即可。

image.png

然后我还是按照 "React 后遗症" 的写法,父组件还需要再提供一个改变这个属性值的方法。

image.png

接下来要去子组件接受传递过来的 Props

36cddca174224ed2b91711129b2a12b8_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg

嗯,看起来功能是正常的。最开始我也是这样想的,但是 leader 说,现在需要点击 <Content/> 区域也可以关闭这个弹出框。我心想,这还不简单啊,我直接给 <Content> 也加上这个点击事件不就行了吗?

image.png

效果如下:

cc152ce0188d4c35ac6ad1854d30e7f8_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg

是不是乍一看好像没什么问题,但是我发现如果简单这样的话有个很严重的 BUG ,我点击 <Content/> 区域这个选项框也会出现了。

于是我就改变了 changeShow 这个函数的逻辑。我把它拆分成了两份。

image.png

同样的,我们<Header/> 组件也得接收两个函数。

image.png

我们的 <Header> 组件内部也变成了这样子

image.png

然后把 Content 的点击事件更换为 closeOptions 函数,我们试一下效果。

cc152ce0188d4c35ac6ad1854d30e7f8_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg

相关文章
|
2月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
163 64
|
26天前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
99 3
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
57 8
|
2月前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
52 1
|
2月前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
58 1
|
2月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
JavaScript 前端开发 UED
如何在 Vue 自定义组件中正确使用 v-model 进行数据的双向绑定?
如何在 Vue 自定义组件中正确使用 v-model 进行数据的双向绑定?
241 0
|
JavaScript 前端开发 算法
web前端面试高频考点——Vue组件间的通信及高级特性(多种组件间的通信、自定义v-model、nextTick、插槽)
web前端面试高频考点——Vue组件间的通信及高级特性(多种组件间的通信、自定义v-model、nextTick、插槽)
157 0
|
JavaScript
Vue:自定义v-model数据双向绑定
Vue:自定义v-model数据双向绑定
141 0
Vue:自定义v-model数据双向绑定
|
容器 JavaScript
Vue自定义v-model
版权声明:本文首发 http://asing1elife.com ,转载请注明出处。 https://blog.csdn.net/asing1elife/article/details/82811783 ...
1120 0