vue 组件开发原理与实现方法详解
程序员文章站
2022-06-24 16:23:36
本文实例讲述了vue 组件开发原理与实现方法。分享给大家供大家参考,具体如下:
概要
vue 的一个特点是进行组件开发,组件的优势是我们可以封装自己的控件,实现重用,比如我们在平台...
本文实例讲述了vue 组件开发原理与实现方法。分享给大家供大家参考,具体如下:
概要
vue 的一个特点是进行组件开发,组件的优势是我们可以封装自己的控件,实现重用,比如我们在平台中封装了自己的附件控件,输入控件等。
组件的开发
在vue 中一个组件,就是一个独立的.vue 文件,这个文件分为三部分。
1.模板
2.脚本
3.样式
我们看一个系统中最常用的组件。
<template> <div > <div v-if="right=='r'" class="readonlybgcolor">{{value}}</div> <div class="box-custom-component" v-else-if="right=='w'"> <input type="text" @blur="blurhandler" @focus="focushandler" :required="required" v-model="currentvalue" :placeholder="placeholder" ></input> <a href="javascript:;" rel="external nofollow" class="yd-input-clear" tabindex="-1" @click="clearinput" v-show="showclear && !isempty"></a> </div> </div> </template> <script type="text/ecmascript-6"> import { calcright } from "@/assets/app.js"; import {vtypes,rxutil} from "@/assets/util.js"; export default{ name : "rx-input", props: { value:[string,number], permission:object, permissionkey:string, showclear:{ type: boolean, default: true }, readonly: { type: boolean, default: false }, placeholder:{ type: string, default: "" }, required: { type: boolean, default: false }, /** * 验证表达式 */ vtype:{ type: string, default: "" }, onblur:function, onfocus:function, conf:object }, data(){ return { currentvalue: this.value, iserror:false, isempty:true, checkreq:true } }, computed: { right :function () { return calcright(this); } }, mounted(){ this.valid(this.required); }, methods: { valid(chkreq_) { var val=this.currentvalue; if(chkreq_ && this.required){ if(rxutil.isempty(val)){ // this.iserror=true; return false; } } if(!this.vtype) { // this.iserror=false; return true; } var validfunc=vtypes[this.vtype]; if(typeof validfunc=="undefined") { // this.iserror=false; return true; } //验证 var rtn= validfunc.valid(val); // this.iserror=!rtn; return rtn; }, blurhandler(e) { // this.iserror=!this.valid(this.checkreq); this.onblur && this.onblur(e); }, focushandler(e) { this.showclear = true; this.onfocus && this.onfocus(e); }, clearinput(){ this.currentvalue = ''; if(this.required){ // this.iserror=true; } } }, watch: { currentvalue: function (val, oldval){ this.$emit('input', this.currentvalue); //是否为空 this.isempty=rxutil.isempty(val); }, value :function(val,oldval){ if(val!=oldval){ this.currentvalue=this.value; } } } } </script> <style scoped> .box-custom-component::after{ content: ''; display: block; clear: both; } .box-custom-component input{ float: left; width:calc(100% - .65rem); } .box-custom-component a{ float: left; width: .65rem; } </style>
定义好组件后,使用方法如下:
1.import 组件
import rxinput from '@/components/common/form/rxinput';
2.注册组件
vue.component(rxinput.name, rxinput);
3.使用组件
<rx-input v-model="data.email" permissionkey="email" :required="true" vtype="email" :readonly="false" :permission="" ></rx-input>
这里我们定义了v-model 我们通过将数据绑定到组件上实现数据的双向绑定。
实现双向绑定,需要注意两点:
1.定义一个value 的属性。
在上面组件的代码中,我们可以看到我们定义了一个value属性。
在只读的情况下 直接绑定显示。
<div v-if="right=='r'" class="readonlybgcolor">{{value}}</div>
另外我们在data定义上,将value 赋值给了 currentvalue 。这个值绑定到输入控件上。
2.数据改变时调用方法。
this.$emit('input', this.currentvalue);
这样就实现了数据的双向绑定。
希望本文所述对大家vue.js程序设计有所帮助。
上一篇: 干这行比我更有前途
下一篇: Vue.js 无限滚动列表性能优化方案