利用vue组件创建模板,使用webpack打包生成插件再全局使用
1、vue init webpack-simple 生成项目目录
2、调整目录结构
3、修改webpack.config.js
module.exports = {
entry: './src/index.js',output: {
path: path.resolve(__dirname,'./dist'),publicPath: '/dist/',filename: 'vue-toast.js',// 打包后的格式(三种规范amd,cmd,common.js)通过umd规范可以适应各种规范,以及全局window属性
libraryTarget:'umd',},module: {
rules: [
{
test: /.vue$/,loader: 'vue-loader',{
test: /.js$/,loader: 'babel-loader',exclude: /node_modules/
},]
},plugins:[]
}
entry: './src/index.js',output: {
path: path.resolve(__dirname,'./dist'),publicPath: '/dist/',filename: 'vue-toast.js',// 打包后的格式(三种规范amd,cmd,common.js)通过umd规范可以适应各种规范,以及全局window属性
libraryTarget:'umd',},module: {
rules: [
{
test: /.vue$/,loader: 'vue-loader',{
test: /.js$/,loader: 'babel-loader',exclude: /node_modules/
},]
},plugins:[]
}
开发一个toast插件,可以借助npm平台发布,在这里就不做过多的说明了
toast.vue
index.js
{
if(!toast) {
toast = new VueToast()
toast.$mount()
document.querySelector(options.container || 'body').appendChild(toast.$el)
}
toast.show(params)
resolve()
})
}
Vue.prototype.$toast = $toast
}
if(window.Vue){
Vue.use(Toast)
}
export default Toast
npm run build 之后就会在根目录下生成dist文件
接下来就可以使用了
demo.html