vue 组件使用中的一些细节点


Posted in Javascript onApril 25, 2018

细节一

基础例子

vue 组件使用中的一些细节点

运行结果:

vue 组件使用中的一些细节点

以上大家都懂,这边就不多说,回到代码里,有时候我们需要 tbody 里面每一行是一个子组件,那我们代码可以怎么写呢?我们可以这样写,定义一个全局组件,如下:

vue 组件使用中的一些细节点

然后我们在 body 里面可以这么调用:

vue 组件使用中的一些细节点

运行结果:

vue 组件使用中的一些细节点

可以看到 row 是有打印出来了,但它实际上里面没有任务内容,那我们的问题出在哪呢?回到代码我们发现我们在创建 vue 实例的时候没有指定要挂载的点,所以我们通过 el 来指定 vue 接管的 Dom ,如下:

vue 组件使用中的一些细节点

运行结果:

vue 组件使用中的一些细节点

感觉上没有问题,但真的是这样吗?我们通过检查元素,查看DOM结构:

vue 组件使用中的一些细节点

大家可以看到出错啦?正常的三个 tr 应该是在 tbody 里面, 而现在跑到跟 tbody 同一层了,这是怎么回事呢?

在H5的规范里面,要求我们 table 里面有 tbody, tbody 里面必须得放 tr,而现在我们使用子组件里面写成 row, 所以我们的浏览器在解析的时候就会出问题。

那么我们一旦遇到这种情况出现 bug 要怎么解呢? 这时候我们可以借助 vue 提供的 is 属性来解决这个问题。很简单, tbody 里面只能写 tr, 那我们就都写 tr,可是实际上我们要显示 tr 并不是就真的只显示 tr 空的内容,我们需要显示 row 组件的内容,那怎么做?

我们可以在 tr 多一个属性is 让它等于 row, 如下:

vue 组件使用中的一些细节点

这段代码的意思是:我要用一个组件,但是我不能直接写这个组件,所以我们写了一个 tr, 我们用 is 表示虽然我写的是 tr, 但它表示是 row 组件,这样能既能符合 H5 的规范又能显示我们组件的内容 ,程序就不会有 bug 了。

运行结果:

vue 组件使用中的一些细节点

一切正常。

同样我们使用 ul, select 标签的时候,也可以用这种方法。

细节二

基础例子

vue 组件使用中的一些细节点

我们定义了一个组件 row,里面有段文本,如果我们想把这段文本单独提取出来用变量表示 ,那么你很有可能会这样写:

vue 组件使用中的一些细节点

看似完美,在打开浏览器运行你会发现,bug 正向你招手:

vue 组件使用中的一些细节点

主要意思是 data 是要一个函数,而不是一个对象,什么情况,在根组件,也就是最外层 vue 的实例,我们通过对象定义是 ok 的,但是在非根组件的子组件这样定义是不行滴。data 定义要求是一个函数,同时这个函数要求返回一个对象,如下:

vue 组件使用中的一些细节点

运行结果:

vue 组件使用中的一些细节点

这样问题就解决啦。

之所以这么定义,原因是一个子组件不像根组件只被调用一次,而是可以多次调用,那么每一个子组件的数据我们不希望和其它的子组件产生冲突或者说每个子组件都应该有一个自己的数据域,通过函数返回一个对象就可以实现这个需求。

细节三

基础例子

vue 组件使用中的一些细节点

运行,点击弹出click,没毛病。vue 不建议我们在代码里面操作 Dom, 但是在处理一些极其复杂的动画效果,我们还真得操作 Dom, 那么在 vue 中如何操作 Dom 呢? 我们可以通过 ref 引用的方式,如下:

vue 组件使用中的一些细节点

这时候我们有个需求,就是点击div 的时候,把里面的内容打印出来,我们可以通过引用获取div节点,然后打印div 里面的内容即可:

vue 组件使用中的一些细节点

运行结果:

vue 组件使用中的一些细节点

总结

以上所述是小编给大家介绍的vue 组件使用中的一些细节点,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS实现不使用图片仿Windows右键菜单效果代码
Oct 22 Javascript
jQuery基于ajax()使用serialize()提交form数据的方法
Dec 08 Javascript
jQuery的$.extend 浅拷贝与深拷贝
Mar 08 Javascript
JS操作xml对象转换为Json对象示例
Mar 25 Javascript
Vue组件通信实践记录(推荐)
Aug 15 Javascript
javaScript 连接打印机,打印小票的实例
Dec 29 Javascript
浅谈VUE监听窗口变化事件的问题
Feb 24 Javascript
浅谈Vue响应式(数组变异方法)
May 07 Javascript
详解React-Router中Url参数改变页面不刷新的解决办法
May 08 Javascript
微信小程序踩坑记录之解决tabBar.list[3].selectedIconPath大小超过40kb
Jul 04 Javascript
JS实现将二维数组转为json格式字符串操作示例
Jul 12 Javascript
原生js实现html手机端城市列表索引选择城市
Jun 24 Javascript
Vue中使用vue-i18插件实现多语言切换功能
Apr 25 #Javascript
vue项目中vue-i18n和element-ui国际化开发实现过程
Apr 25 #Javascript
父组件中vuex方法更新state子组件不能及时更新并渲染的完美解决方法
Apr 25 #Javascript
vue短信验证性能优化如何写入localstorage中
Apr 25 #Javascript
详解Vue.js中.native修饰符
Apr 24 #Javascript
Vue 动态设置路由参数的案例分析
Apr 24 #Javascript
vue.js前后端数据交互之提交数据操作详解
Apr 24 #Javascript
You might like
php实现图形显示Ip地址的代码及注释
2014/01/20 PHP
PHP中使用gettext解决国际化问题的例子(i18n)
2014/06/13 PHP
php实现按照权重随机排序数据的方法
2015/01/09 PHP
纯php生成随机密码
2015/10/30 PHP
文本框的字数限制功能jquery插件
2009/11/24 Javascript
更换select下拉菜单背景样式的实现代码
2011/12/20 Javascript
再谈javascript面向对象编程
2012/03/18 Javascript
jQuery实现移动 和 渐变特效的点击事件
2015/02/26 Javascript
快速学习jQuery插件 jquery.validate.js表单验证插件使用方法
2015/12/01 Javascript
基于JS代码实现实时显示系统时间
2016/06/16 Javascript
javascript数组对象常用api函数小结(连接,插入,删除,反转,排序等)
2016/09/20 Javascript
简单的渐变轮播插件
2017/01/12 Javascript
详解webpack介绍&安装&常用命令
2017/06/29 Javascript
Angular 4.X开发实践中的踩坑小结
2017/07/04 Javascript
vue-cli 使用vue-bus来全局控制的实例讲解
2018/09/15 Javascript
如何在vue里面优雅的解决跨域(路由冲突问题)
2019/01/20 Javascript
教你完全理解ReentrantLock重入锁
2019/06/03 Javascript
Vue清除定时器setInterval优化方案分享
2020/07/21 Javascript
[01:43]深扒TI7聊天轮盘语音出处4
2017/05/11 DOTA
python实现中文分词FMM算法实例
2015/07/10 Python
Python实现多线程抓取网页功能实例详解
2017/06/08 Python
Python搜索引擎实现原理和方法
2017/11/27 Python
Django自定义用户认证示例详解
2018/03/14 Python
Python反射和内置方法重写操作详解
2018/08/27 Python
在Qt中正确的设置窗体的背景图片的几种方法总结
2019/06/19 Python
python中的&&及||的实现示例
2019/08/07 Python
python对象转字典的两种实现方式示例
2019/11/07 Python
Pandas-Cookbook 时间戳处理方式
2019/12/07 Python
html5中canvas学习笔记2-判断浏览器是否支持canvas
2013/01/06 HTML / CSS
苏宁红孩子母婴商城:redbaby
2017/02/12 全球购物
W Concept美国:精选全球独立设计师
2017/02/22 全球购物
Lookfantastic美国/加拿大:英国知名美妆购物网站
2019/03/27 全球购物
Clarks西班牙官方在线商店:clarks鞋
2019/05/03 全球购物
2014全国两会心得体会
2014/03/17 职场文书
合作合同协议书范本
2015/01/27 职场文书
带你了解Java中的ForkJoin
2022/04/28 Java/Android