Rumah >hujung hadapan web >uni-app >Panduan Reka Bentuk dan Pembangunan UniApp untuk Melaksanakan Arahan Tersuai dan Enkapsulasi Operasi
Panduan Reka Bentuk dan Pembangunan UniApp untuk Melaksanakan Arahan Tersuai dan Enkapsulasi Operasi
1 Pengenalan
Dalam pembangunan UniApp, kami sering menghadapi beberapa operasi berulang atau keperluan UI biasa Untuk meningkatkan kebolehgunaan semula dan kebolehgunaan kod, Kebolehselenggaraan boleh dicapai dengan menggunakan arahan tersuai dan enkapsulasi operasi. Artikel ini akan memperkenalkan cara mereka bentuk dan membangunkan arahan tersuai dan pakej operasi dalam UniApp, dan menerangkannya dengan contoh kod. Arahan peribadi fungsi cangkuk perintah. UniApp mewarisi fungsi arahan tersuai Vue.js Kami boleh melaksanakan fungsi arahan tersuai dalam UniApp dengan mentakrifkan arahan global.
Cara mentakrifkan arahan tersuai
Sangat mudah untuk menentukan arahan tersuai dalam UniApp, kami hanya perlu memperkenalkan dalam fail <code>main.js
uni-app code> fail uni.vue.mixin.js
dan tambahkan arahan tersuai yang kami takrifkan dalam atribut mixin
App
. // main.js import Vue from 'vue' import App from './App' import '@/uni.vue.mixin.js' Vue.config.productionTip = false App.mpType = 'app' const app = new Vue({ ...App }) app.$mount()
// uni.vue.mixin.js export default { directives: { customDirective: { bind(el, binding) { // 指令生效时执行的函数 // el为绑定指令的dom元素,binding为指令的绑定值 // 在此处可以根据实际需求对DOM元素进行操作 }, update(el, binding) { // 指令的绑定值发生改变时执行的函数 // 在此处可以根据实际需求对DOM元素进行更新操作 }, unbind(el) { // 指令解绑时执行的函数 // 在此处可以对之前绑定的事件进行解绑操作 } } } }
v-custom-directive
dalam templat Vue. uni-app
项目的main.js
文件中引入uni.vue.mixin.js
文件,并在App
的mixin
属性中添加我们定义的自定义指令即可。<template> <view v-custom-directive="value"></view> </template> <script> export default { data() { return { value: 'Hello World' } } } </script>
// utils.js export function uploadImage(file) { return new Promise((resolve, reject) => { uni.uploadFile({ url: 'http://example.com/api/upload', filePath: file.path, name: 'file', success(res) { if (res.statusCode === 200 && res.data) { resolve(res.data) } else { reject(new Error('上传失败')) } }, fail(error) { reject(error) } }) }) }
v-custom-directive
<template> <view> <input type="file" @change="handleFileChange" /> <button @click="upload">上传</button> </view> </template> <script> import { uploadImage } from 'utils.js' export default { data() { return { file: null } }, methods: { handleFileChange(e) { this.file = e.target.files[0] }, async upload() { try { const res = await uploadImage(this.file) console.log(res) // 处理上传成功后的逻辑 } catch (error) { console.error(error) // 处理上传失败后的逻辑 } } } } </script>
Atas ialah kandungan terperinci Panduan Reka Bentuk dan Pembangunan UniApp untuk Melaksanakan Arahan Tersuai dan Enkapsulasi Operasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!