Rumah >hujung hadapan web >Soal Jawab bahagian hadapan >Apakah maksud pembangunan komponen vue?
Dalam Vue, pembangunan komponen merujuk kepada pembahagian perniagaan yang kompleks kepada berbilang komponen, dan CSS, JS, templat, gambar dan sumber lain yang setiap komponen bergantung kepada dibangunkan dan diselenggara bersama. Oleh kerana komponen bebas daripada sumber, ia boleh digunakan semula dalam sistem, sangat memudahkan jumlah kod, dan lebih mesra untuk meminta perubahan dan penyelenggaraan kemudian.
Persekitaran pengendalian tutorial ini: sistem Windows 7, vue versi 2.9.6, komputer DELL G3.
Apakah komponenisasi
vue.js mempunyai dua keajaiban Satu utama senjata adalah didorong oleh data dan yang lain adalah komponenisasi Jadi persoalannya, apakah komponenisasi dan mengapa ia perlu? Seterusnya, saya akan menjawab dua soalan ini satu demi satu Apa yang dipanggil komponenisasi adalah untuk membahagikan halaman kepada berbilang komponen, dan CSS, JS, templat, gambar dan sumber lain yang bergantung pada setiap komponen dibangunkan dan diselenggara. bersama. Oleh kerana komponen tidak bergantung pada sumber, ia boleh digunakan semula dalam sistem, dan komponen boleh disarangkan jika projek itu rumit, jumlah kod boleh dipermudahkan, dan perubahan permintaan dan penyelenggaraan akan menjadi lebih mudah .
1. Pembangunan komponen merujuk kepada pembahagian perniagaan yang kompleks kepada komponen satu demi satu
2 Komponen pembangunan komponen secara amnya perlu fleksibel
3. Pembangunan komponen melibatkan js Vue. enkapsulasi komponen, dan anda perlu menguasai asas Vue, kaedah dan sifat contoh Vue, Vue.extend, pemalam Vue, dll.
Bagaimana untuk menjalankan pembangunan komponen
Lihat gambar di bawah:
Ini adalah ralat dalam vue.js bahawa komponen tidak berdaftar lx-xxx
digunakan. Ralat ini memberitahu kami kebenaran: mesti mendaftar sebelum menggunakan komponen tersuai.
Jadi bagaimana untuk mendaftar komponen? Vue.js menyediakan dua cara untuk mendaftar komponen, pendaftaran global dan pendaftaran tempatan.
Dalam vue.js kita boleh menggunakan Vue.component(tagName, options) untuk pendaftaran global, seperti
Vue.component('my-component', { // 选项 })
Vue.js juga menyokong pendaftaran separa Kami boleh menggunakan pilihan komponen di dalam komponen untuk melakukan pendaftaran separa komponen, contohnya:
import HelloWorld from './components/HelloWorld' export default { components: { HelloWorld } }
Perbezaan: Komponen global dipasang di bawah Vue.options.components
, manakala komponen tempatan dipasang di bawah vm.$options.components
Inilah sebabnya mengapa komponen yang didaftarkan secara global boleh digunakan sewenang-wenangnya.
Bak kata pepatah, jika anda ingin melakukan kerja anda dengan baik, anda mesti mengasah alat anda terlebih dahulu komponen, kita mesti terlebih dahulu Untuk menguasai beberapa pengetahuan yang diperlukan, saya hanya akan memperkenalkannya secara ringkas di sini Sila rujuk laman web rasmi untuk butiran.
nama
Nama komponen, diperlukan
<lx-niu/> <lx-niu></lx-niu/> name: 'lxNiu'
Gunakan perintah kes unta dalam js, gunakan kebab untuk penamaan kes HTML.
props
Sifat komponen, digunakan untuk komunikasi komponen ibu bapa-anak, boleh diakses melalui ini.msg
<div>{{msg}}</div> props: { msg: { type: String, default: '' } } show: Boolean // 默认false msg: [String, Boolean] // 多种类型
dikira
Memproses atribut dalam data atau prop dan mengembalikan atribut baharu
<div>{{newMsg}}</div> computed: { newMsg() { return 'hello ' + this.msg } },
Nota: Kerana prop, data dan dikira disusun Peringkat akan digabungkan sebagai atribut vm, jadi ia tidak boleh dinamakan semula
memberi
Gunakan fungsi render untuk menerangkan templat
<lx-niu tag='button'>hello world</lx-niu> <script type="text/javascript"> export default { name: 'lxNiu', props: { tag: { type: String, default: 'div' }, }, // h: createElement render(h) { return h(this.tag, {class: 'demo'}, this.$slots.default) } } </script>
h dalam render sebenarnya createElement, yang menerima tiga parameter dan mengembalikan vnode
h penjelasan parameter:
args1: {string | Function | Object} digunakan untuk menyediakan kandungan html DOM
args2: { Objek} Tetapkan gaya DOM, sifat, peristiwa mengikat, dsb.
args3: {array} Digunakan untuk menetapkan kandungan yang diedarkan
Nota: Urutan kompilasi Vue: templat–> render - -> vnode --> tampalan -->
kelas
Tentukan nama kelas subkomponen<lx-niu> <div slot='header'>header</div> <div class="body" slot='body'> <input type="text"> </div> <div slot='footer'>footer</div> <button class='btn'>button</button> </lx-niu> <template> <div> <slot name='header'></slot> <slot name='body'></slot> <slot name='footer'></slot> <slot></slot> </div> </template> <script> export default { name: 'lxNiu', mounted() { this.$slots.header // 包含了slot="foo"的内容 this.$slots.default // 得到一个vnode,没有被包含在具名插槽中的节点,这里是button } } </script>
gayaTeruskan gaya kepada komponen kanak-kanak
// 父组件 <lx-niu round type='big'/> // 子组件 <div :class="[ type ? 'lx-niu__' + type : '', {'is-round': round}, ]">控制</div> //真实DOM <div class='lx-niu__big is-round'>hello</div>
Atribut lain
$attrs// 父组件 <lx-niu :bodyStyle='{color: "red"}'/> // 子组件 <template> <div :style='bodyStyle'>hello world</div> </template> <script> export default { name: 'lxNiu', props: { bodyStyle: {}, }, } </script>v-bind="$attrs" Tambahkan atribut selain kelas dan gaya kepada komponen induk, seperti mentakrifkan input:
v-sekali
Komponen hanya dipaparkan sekali, dan tidak akan dipaparkan semula walaupun data berubah kemudian. Contohnya, dalam contoh, val tidak akan menjadi 456
campuran.
<input v-bind="$attrs">
// mixin.js export default { data() { return{ msg: 'hello world' } }, methods: { clickBtn() { console.log(this.msg) } }, } // index.vue <button @click="clickBtn">button</button> import actionMixin from "./mixin.js"; export default { methods: {}, mixins: [actionMixin] }
比如我们要注册一个 lx-button 这样一个组件,那么目录和伪代码如下:
index.vue
<template> <button>lxButton</button> </template> <script> export default { name: 'lxButton' } </script>
index.js
import lxButton from './src/index' lxButton.install = (Vue) => { Vue.component(lxButton.name, lxButton) } export default lxButton
其中 install
是 Vue.js 提供了一个公开方法,这个方法的第一个参数是 Vue 构造器,第二个参数是一个可选的选项对象。MyPlugin.install = function (Vue, options){}
参考: 开发插件
https://cn.vuejs.org/v2/guide/plugins.html#%E5%BC%80%E5%8F%91%E6%8F%92%E4%BB%B6
watch-弹窗实现原理
<button @click="dialogVisible = true">显示</button> <lx-niu :visible.sync="dialogVisible"></lx-niu> <script> export default { data() { return { dialogVisible: false } }, watch: { dialogVisible(val) { console.log('father change', val) } } } </script>
定义组件
<template> <div v-show="visible"> <button @click="hide">关闭</button> </div> </template> <script> export default { name: 'lxNiu', props: { visible: Boolean }, watch: { visible(val) { console.log('child change:', val) } }, methods: { hide() { this.$emit('update:visible', false); } }, } </script>
点击父组件中的显示
按钮,改变传入子组件中的值,点击子组件中的关闭
,改变父组件中值。
注:@click=“dialogVisible = true” 点击时将dialogVisible的值改为true
注::visible.sync: 双向数据绑定,配合update:visible使用,实现子组件修改父组件中的值
官网解释: sync
col组件实例
export default { name: 'ElCol', props: { span: { type: Number, default: 24 }, tag: { type: String, default: 'div' }, offset: Number, pull: Number, push: Number, xs: [Number, Object], sm: [Number, Object], md: [Number, Object], lg: [Number, Object], xl: [Number, Object] }, computed: { gutter() { let parent = this.$parent; while (parent && parent.$options.componentName !== 'ElRow') { parent = parent.$parent; } return parent ? parent.gutter : 0; } }, render(h) { let classList = []; let style = {}; if (this.gutter) { style.paddingLeft = this.gutter / 2 + 'px'; style.paddingRight = style.paddingLeft; } ['span', 'offset', 'pull', 'push'].forEach(prop => { if (this[prop] || this[prop] === 0) { classList.push( prop !== 'span' ? `el-col-${prop}-${this[prop]}` : `el-col-${this[prop]}` ); } }); ['xs', 'sm', 'md', 'lg', 'xl'].forEach(size => { if (typeof this[size] === 'number') { classList.push(`el-col-${size}-${this[size]}`); } else if (typeof this[size] === 'object') { let props = this[size]; Object.keys(props).forEach(prop => { classList.push( prop !== 'span' ? `el-col-${size}-${prop}-${props[prop]}` : `el-col-${size}-${props[prop]}` ); }); } }); return h(this.tag, { class: ['el-col', classList], style }, this.$slots.default); } };
col组件使用render函数,而不是template来实现组件,原因有两个:
该组件有大量的类判断,如果采用template代码比较冗余,使用js代码更加简洁
直接render描述性能更好
官网解释: render-function
button组件实例
<template> <button class="el-button" @click="handleClick" :disabled="buttonDisabled || loading" :autofocus="autofocus" :type="nativeType" :class="[ type ? 'el-button--' + type : '', buttonSize ? 'el-button--' + buttonSize : '', { 'is-disabled': buttonDisabled, 'is-loading': loading, 'is-plain': plain, 'is-round': round, 'is-circle': circle } ]" > <i class="el-icon-loading" v-if="loading"></i> <i :class="icon" v-if="icon && !loading"></i> <span v-if="$slots.default"><slot></slot></span> </button> </template> <script> export default { name: 'ElButton', inject: { elForm: { default: '' }, elFormItem: { default: '' } }, props: { type: { type: String, default: 'default' }, size: String, icon: { type: String, default: '' }, nativeType: { type: String, default: 'button' }, loading: Boolean, disabled: Boolean, plain: Boolean, autofocus: Boolean, round: Boolean, circle: Boolean }, computed: { _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, buttonSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, buttonDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, methods: { handleClick(evt) { this.$emit('click', evt); } } }; </script>
局部组件实例
<template> <div class="login"> <login-header /> <login-request /> <login-footer /> </div> </template> <script> import loginHeader from './login-header'; import loginRequest from './login-request'; import loginFooter from './login-footer'; export default { components: { [loginHeader.name]: loginHeader, [loginRequest.name]: loginRequest, [loginFooter.name]: loginFooter } }; </script>
8. 分享总结
【相关推荐:《vue.js教程》】
Atas ialah kandungan terperinci Apakah maksud pembangunan komponen vue?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!