其实就跟组件差不多意思,组件也可以实现相关的效果,但要在用到的地方都引用
插件就可以全局注册,不需引用

试着撸一个插件,有2个功能,提示和对话框

网上找了个toast插件的代码,改了改,扩展加了个dialog,增加了注释

插件文件结构

在入口文件中注册:

/* 自定义插件 */
import {Message,vDialog} from './components/vtoast/index'
Vue.use(Message).use(vDialog)

调用方式

    methods:{
showtoast(){
this.$vtoast({
duration:1100,
message:'哈哈哈'
});
},
showdialog(){
let that = this
this.$vdialog.alert({
isShow: true,
//插件默认值title为空,如果这里不放title,则不会显示title的dom
title:'你好',
message:'哈哈哈',
})
.then(()=>{
that.test = '修改了'
})
}
},

toast.vue:

<template>
<transition name="fade">
<div class="v-msg" v-show="isShow">
<span>{{message}}</span>
</div>
</transition>
</template> <script>
export default { data(){
return {
message: '默认提示',
isShow : false
}
},
methods:{
close(){
this.isShow = false
},
show(){
this.isShow = true
}
}
}
</script> <style>
.v-msg{
color:#fff;display: inline-block;background-color:rgba(0,0,0,0.8);padding:10px;
border-radius: 4px;
position: fixed;left:50%;bottom:10px;transform: translateX(-50%)
}
.fade-enter-active, .fade-leave-active { transition: all .2s; }
.fade-enter, .fade-leave-to { opacity: 0; }
</style>

dialog.vue:

<template>
<transition name="fade">
<div v-show="isShow">
<div class="dialog_mask" v-show="mask" @click="close"></div>
<div class="dialog">
<div class="title" v-show="title">{{title}}</div>
<div class="message">{{message}}</div>
<div class="btgroup">
<button class="button" @click="close" v-if="cancle">取消</button>
<button class="button sure" @click="cb();close()">确定</button>
</div>
</div>
</div>
</transition>
</template> <script>
export default {
props:{ },
data(){
return {
title:'',
message:'默认内容消息',
isShow : false,
mask:true,
cancle:false
}
},
methods:{
close(){
this.isShow = false;
}
}
}
</script> <style lang="less" scoped> .dialog_mask{
position: fixed;top:0;right:0;bottom: 0;left: 0;background-color:rgba(0,0,0,0.8);
z-index: 100000;
}
.dialog{
min-width:90vw;max-width:90vw;color:#333;display: inline-block;background-color: #fff;overflow: hidden;
position: fixed;left:50%;top:50%;transform: translate(-50%,-50%);z-index:100001;border-radius:5px;
.title{
font-size:16px;padding:20px 0px 0px;text-align: center;
}
.message{
color:#999;font-size:16px;padding:25px;
}
.btgroup{
display:flex;align-items: center;justify-content: space-between;border-top:1px solid #eee;
}
.button{
font-size:16px;flex:1;padding:14px 0px;border:none;background-color: #fff;
&.sure{color:#293}
&:active{background-color: #eee;}
&:nth-child(2){border-left:1px solid #eee;}
}
}
.fade-enter-active, .fade-leave-active { transition: all .2s; }
.fade-enter, .fade-leave-to { opacity: 0; } </style>

index.js

//插件的install会放入vue.use方法中运行,本文件中不用import vue

// TOAST插件
import mytoast from './toast.vue'
const Message = {}
Message.install = function (Vue, options) {
//返回一个vue实例构造器
const VUECONSTRUCTOR = Vue.extend(mytoast)
let _VUEINSTANCE
const initInstance = () => {
//实例化vue示例 下面可以直接调用methods里面的方法
_VUEINSTANCE = new VUECONSTRUCTOR()
// 取得经过vue里面折腾之后生成的html
let El = _VUEINSTANCE.$mount().$el
//挂载到body中
document.body.appendChild(El)
}
Vue.prototype.$vtoast = (options)=>{
//单例模式,防止重复挂载html
if (!_VUEINSTANCE) {
initInstance()//创建实例
}
//将调用的参数对象传给_VUEINSTANCE对象,覆盖组件内的初始配置
// 官方:https://cn.vuejs.org/v2/guide/list.html#对象更改检测注意事项
Object.assign(_VUEINSTANCE, options) //调用插件里的显示方式
_VUEINSTANCE.show()
// 注意,如果是自动消失的toast 每闪调用(显示),都要再次聊友
// 不要使用实例里面的方法,因为插件只挂载一次,dom便存于html中
// 所以,这里的vue插件实例生命周期只生效一次(created,mounted)
setTimeout(() => {
_VUEINSTANCE.close()
}, options.duration)
}
} // DIALOG插件
import myDialog from './dialog.vue'
const vDialog = {}
vDialog.install = function (Vue, options) {
const VUECONSTRUCTOR = Vue.extend(myDialog)
let _VUEINSTANCE
const initInstance = () => {
_VUEINSTANCE = new VUECONSTRUCTOR()
let El = _VUEINSTANCE.$mount().$el
document.body.appendChild(El)
}
//这里最好用对象封装方法的模式,调用时代码好阅读一些
Vue.prototype.$vdialog = {
alert(options) {
if (!_VUEINSTANCE) {
initInstance()
}
//默认显示显示确定按钮,所以回调给一个默认空函数
Object.assign(_VUEINSTANCE, options,{cb:()=>{}})
//以便连续调用
return this
},
then(options){
//如果不调用then只显示确定按钮
//这里的回调函数名cb,必需和插件里面所调用的一样
Object.assign(_VUEINSTANCE, {cancle:true,cb:options})
}
}
} export {Message,vDialog}

总结相关要点:

  • 绑定多个事件使用  @click="cb();close()"
  • Object.assign(_VUEINSTANCE, options) ,把调用时的参数(包括值,方法)合并进基于vue构造器创建的插件实例中
    vue会自动把参数放到对应的地方,数据放data,方法放methods,但本实践没有把回调方法也放进同一个参数中
    而是为了代码清晰,另起一个连续调用的方法来处理

vue插件开发实践与要点的更多相关文章

  1. Vue项目实践中的功能实现与要点

    本贴记录项目实践中,各种功能的实现与技术要点,均有待改进. 路由切换的时候,显示loading动画 目前方案是: 在每个页面都手动装载一个loading组件组件的显示依赖vuex里面的一个值 , 在r ...

  2. Vue插件开发入门

    相对组件来说,Vue 的插件开发受到的关注要少一点.但是插件的功能是十分强大的,能够完成许多 Vue 框架本身不具备的功能. 大家一般习惯直接调用现成的插件,比如官方推荐的 vue-router.vu ...

  3. 一个简单的 vue.js 实践教程

    https://segmentfault.com/a/1190000006776243?utm_source=tuicool&utm_medium=referral 感觉需要改善的地方有: ( ...

  4. 【转】vue项目重构技术要点和总结

    vue数据更新, 视图未更新 这个问题我们经常会遇到,一般是vue数据赋值的时候,vue数据变化了,但是视图没有更新.这个不算是项目重构的技术要点,也和大家分享一下vue2.0通常的解决方案吧! 解决 ...

  5. prerender-spa-plugin预处理vue项目实践

    由于公司想要把商城做由之前的php和前端混合开发改版为前后端分离,所以拿现在手上的vue项目来实践一下 https://github.com/chrisvfritz/prerender-spa-plu ...

  6. vue+webpack实践

    最近使用了vue来做SPA应用,记一波学习笔记. 使用vue+webpack实现前端模块化. vuejs——轻量.学习成本低.双向绑定.无dom的操作.组件的形式编写 推荐官方文档 vue.js官方文 ...

  7. webpack + vue最佳实践

    webpack + vue最佳实践 我的原文地址:http://www.xiaoniuzai.cn/2016/10/04/webpack%20+%20vue%E6%9C%80%E4%BD%B3%E5% ...

  8. vue初学实践之路——vue简单日历组件(1)

    ---恢复内容开始--- 最近做的项目有一个需求,需要有一个日历组件供预定功能使用,之前的代码过于繁琐复杂,所以我采用vue重写了这个组件. npm.vue等等安装. 只是一个简单的日历组件,所以并不 ...

  9. Vue keep-alive实践总结

    <keep-alive>是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM. <keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是 ...

随机推荐

  1. Bootstrap排版——HTML元素的样式重定义

    前面的话 Bootstrap对默认的HTML元素进行了CSS样式定义,使得各种基本结构套用出来的HTML页面更加美观.本文将详细介绍Bootstrap中排版相关的内容 标题 [h] HTML 中的所有 ...

  2. Spring的 AOP底层用到两种代理机制

    JDK 的动态代理:针对实现了接口的类产生代理.CGlib 的动态代理:针对没有实现接口的类产生代理,应用的是底层的字节码增强的技术 生成当前类的子类对象 JDK动态代理实现1. 创建接口和对应实现类 ...

  3. LightOJ - 1265 (概率)

    题意: 1.两只老虎相遇 就互相残杀 2.老虎与鹿相遇 鹿死 3.老虎与人相遇 人死 4.人与鹿相遇     鹿死 5.鹿与鹿相遇     无果 求人活的概率 解析:如果老虎为0  则人活得概率为1 ...

  4. (python爬取小故事网并写入mysql)

    前言: 这是一篇来自整理EVERNOTE的笔记所产生的小博客,实现功能主要为用广度优先算法爬取小故事网,爬满100个链接并写入mysql,虽然CS作为双学位已经修习了三年多了,但不仅理论知识一般,动手 ...

  5. 自学Python2.10-跳出循环(break、continue)

    自学Python之路 自学Python2.10-跳出循环(break.continue) 1.跳出循环break, 跳出同层的循环 break语句可以跳出for和while的循环体. 如果你从for或 ...

  6. 学习Spring Boot:(二十四)多数据源配置与使用

    前言 随着业务量增大,可能有些业务不是放在同一个数据库中,所以系统有需求使用多个数据库完成业务需求,我们需要配置多个数据源,从而进行操作不同数据库中数据. 正文 JdbcTemplate 多数据源 配 ...

  7. 更新本地git仓库的远程地址(remote地址)

    如果远程仓库的地址更新了,我们本地仓库就需要更新remote地址, 可以通过git remote -v或者cat .git/config查看通信方式及远程地址 更新远程地址的方式有两种: 第一种方式: ...

  8. luogu2831 [NOIp2016]愤怒的小鸟 (状压dp)

    由范围可以想到状压dp 两个点(再加上原点)是可以确定一个抛物线的,除非它们解出来a>=0,在本题中是不合法的 这样的话,我们可以预处理出由任意两个点确定的抛物线所经过的所有的点(要特别规定一下 ...

  9. Coablt strike官方教程中文译版本

    安装和设置 系统要求 Cobalt Strike的最低系统要求 2 GHz +以上的cpu 2 GB RAM 500MB +可用空间 在Amazon的EC2上,至少使用较高核数的CPU(c1.medi ...

  10. Android:更好的自定义字体方案

    http://ryanhoo.github.io/blog/2014/05/05/android-better-way-to-apply-custom-font/ 情景 解决方案 1)Android默 ...