利用Vue v-model实现一个自定义的表单组件


Posted in Javascript onApril 27, 2017

功能描述:

通过点击按钮,可以增减购物数量

组件名称是 CouterBtn

最终效果如下

利用Vue v-model实现一个自定义的表单组件

我们使用 vue-cli搭建基本的开发环境,这也是最快的进行 .vue组件开发的方式

对于入口组件  App.vue (可以暂时忽略其他细节,我们的重点是如何写组件)

App.vue

<template>
 <div id="app">
 <h4>这是一个利用 v-model实现的自定义的表单组件</h4>
 <h6>CouterBtn组件的值 <i> {{ btnValue }} </i></h6>
 5. <counter-btn v-model="btnValue"></counter-btn>
 <form class="" action="/add" method="post">
  <!-- 真实情况请将 type改为hidden -->
  <label for="count">值绑定到 input 隐藏域里</label>
  <input type="text" name="count" :value="btnValue.res" id="count">
10. </form>
 </div>
 </template>
 <script>
 import CounterBtn from './components/CouterBtn.vue'
15. export default {
 data() {
  return {
  btnValue: {}
  }
20. },
 components: {
  CounterBtn
 }
 }
25. </script>
 <style lang="stylus">
 h6 i
 border 1px dotted
 form
30. margin-top 20px
 padding 20px
 border 1px dotted #ccc
 label
  vertical-align: middle
35. </style>

下面我来对 App.vue中的一些代码进行一些说明,根据代码行数来说明

4 : 我们使用 {{ btnValue }}来获取自定义组件 counter-btn的值, 这里仅仅是展示效果用 

5: 我们使用了counter-btn ,自定义的组件 

9: 我们将自定义组件的值,绑定到我们的表单组件 input中去, 在真实的情况下, 此 input的类型可能为 hidden类型 

21: 由于我们需要在App.vue组件中使用我们自定义的组件 counter-btn,所以需要使用 components注册组件, 这里还使用了 ES6的对象解构 

26: 我们使用CSS预处理器为stylus, 前提是你的 node_modules中要安装此npm包和loader,vue-cli已经帮我们处理好了stylus的编译; 根据个人情况选择 

我们自己设计的组件通过 v-model,把组件内部的值传给了它所绑定的值

下面我们来看看我们的组件的实现

CounterBtn.vue

<template>
 <div class="coutter-wrapper">
 <button type="button" @click="plus">+</button>
 <button type="button">{{ result }}</button>
5. <button type="button" @click="minus">-</button>
 </div>
 </template>
 <script>
 export default {
10. methods: {
 minus() {
 this.result--;
 this.$emit('input', {res: this.result, other: '--'})
 },
15. plus() {
 this.result++;
 this.$emit('input', {res: this.result, other: '++'})
 }
 },
20. data() {
 return {
 result: 0,
 }
 }
25. }
 </script>
 <style lang="stylus" scoped>
 button
 border 0
30. outline 0
 border-radius 3px
 button:nth-child(2)
 width 200px 
 </style>

我们可以看到组件的实现非常简单, 3个button搞定; 这里最关键的代码是

this.$emit('input', {res: this.result, other: '++'})

通过 触发 input事件和自定的数据来实现把数据暴露给 v-model绑定的属性值

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木

Javascript 相关文章推荐
SyntaxHighlighter语法高亮插件使用说明
Aug 14 Javascript
jQuery 中使用JSON的实现代码
Dec 01 Javascript
js hover 定时器(实例代码)
Nov 12 Javascript
给应用部分的js代码设定一个统一的入口
Jun 15 Javascript
jQuery中:gt选择器用法实例
Dec 29 Javascript
JQuery控制div外点击隐藏而div内点击不会隐藏的方法
Jan 13 Javascript
详解一个基于react+webpack的多页面应用配置
Jan 21 Javascript
jQuery实现的五星点评功能【案例】
Feb 18 jQuery
通过vue手动封装on、emit、off的代码详解
May 29 Javascript
layUI实现前端分页和后端分页
Jul 27 Javascript
详解CocosCreator消息分发机制
Apr 16 Javascript
vue-cli3.x配置全局的scss的时候报错问题及解决
Apr 30 Vue.js
详解Vue 普通对象数据更新与 file 对象数据更新
Apr 26 #Javascript
微信小程序实现给循环列表添加点击样式实例
Apr 26 #Javascript
微信小程序 request接口的封装实例代码
Apr 26 #Javascript
微信小程序中hidden不生效原因的解决办法
Apr 26 #Javascript
微信小程序 flex实现导航实例详解
Apr 26 #Javascript
微信扫码支付零云插件版实例详解
Apr 26 #Javascript
JavaScript实现的冒泡排序法及统计相邻数交换次数示例
Apr 26 #Javascript
You might like
无数据库的详细域名查询程序PHP版(5)
2006/10/09 PHP
PHP 组件化编程技巧
2009/06/06 PHP
php smarty函数扩展
2010/03/15 PHP
php array_pop()数组函数将数组最后一个单元弹出(出栈)
2011/07/12 PHP
Js sort排序使用方法
2011/10/17 Javascript
使用Post提交时须将空格转换成加号的解释
2013/01/14 Javascript
jQuery实现图片信息的浮动显示实例代码
2013/08/28 Javascript
整理的比较全的event对像在ie与firefox浏览器中的区别
2013/11/25 Javascript
百度判断手机终端并自动跳转js代码及使用实例
2014/06/11 Javascript
微信小程序 label 组件详解及简单实例
2017/01/10 Javascript
微信小程序 template模板详解及实例
2017/02/21 Javascript
backbone简介_动力节点Java学院整理
2017/07/14 Javascript
JavaScript 中定义函数用 var foo = function () {} 和 function foo()区别介绍
2018/03/01 Javascript
vue.js使用v-model实现表单元素(input) 双向数据绑定功能示例
2019/03/08 Javascript
layui实现数据分页功能(ajax异步)
2019/07/27 Javascript
Node.js系列之连接DB的方法(3)
2019/08/30 Javascript
python k-近邻算法实例分享
2014/06/11 Python
Python3字符串学习教程
2015/08/20 Python
Python制作爬虫采集小说
2015/10/25 Python
全面了解Python的getattr(),setattr(),delattr(),hasattr()
2016/06/14 Python
对DataFrame数据中的重复行,利用groupby累加合并的方法详解
2019/01/30 Python
python 批量添加的button 使用同一点击事件的方法
2019/07/17 Python
python爬虫开发之Beautiful Soup模块从安装到详细使用方法与实例
2020/03/09 Python
Django模型中字段属性choice使用说明
2020/03/30 Python
Pyqt助手安装PyQt5帮助文档过程图解
2020/11/20 Python
ECCO爱步美国官网:来自丹麦的鞋履品牌
2016/11/23 全球购物
澳大利亚便宜的家庭购物网站:CrazySales
2018/02/06 全球购物
建筑设计所实习生自我鉴定
2013/09/25 职场文书
技术学校毕业生求职信分享
2013/12/02 职场文书
清明节扫墓活动方案
2014/03/02 职场文书
《梅花魂》教学反思
2014/04/30 职场文书
幼儿园秋季开学寄语
2014/08/02 职场文书
党性锻炼的心得体会
2014/09/03 职场文书
师德先进个人事迹材料
2014/12/19 职场文书
员工辞职信范文
2015/03/02 职场文书
Python开发五子棋小游戏
2022/04/28 Python