vue制作toast組件npm包示例代碼
之前寫了一個(gè)ui組件,但是感覺沒必要的東西太多了,所以做了一下優(yōu)化
介紹
之前制作的小組件是用webpack-simple搭建的,但是左思右想感覺沒必要的東西太多太多,所以又寫了一個(gè)清潔版的,直接開整
開始
建立一個(gè)空文件夾, 然后直接終端運(yùn)行 npm init建立完之后會(huì)生成一個(gè) package.json 文件,內(nèi)容如下
注意:name是之后要發(fā)的npm包的名字 不要重名,建議去npm先搜一下有沒有在取
接下來對(duì) package.json 文件添加所需模塊,
{ 'name': 'sever-ui', 'version': '1.0.0', 'description': '一個(gè)移動(dòng)端ui小組件', 'main': 'index.js', 'scripts': { 'test': 'echo 'Error: no test specified' && exit 1', 'start': 'webpack-dev-server --hot --inline', 'build': 'webpack --display-error-details --config webpack.config.js' }, 'author': 'sever27', 'license': 'ISC', 'devDependencies': { 'babel-core': '^6.26.0', 'babel-loader': '^7.1.2', 'babel-plugin-transform-object-rest-spread': '^6.26.0', 'babel-plugin-transform-runtime': '^6.23.0', 'babel-polyfill': '^6.26.0', 'babel-preset-es2015': '^6.24.1', 'css-loader': '^0.28.7', 'es6-promise': '^4.1.1', 'vue': '^2.5.9', 'vue-hot-reload-api': '^2.2.4', 'vue-html-loader': '^1.2.4', 'vue-style-loader': '^3.0.3', 'vue-template-compiler': '^2.5.9', 'webpack': '^3.9.1', 'webpack-dev-server': '^2.9.5' }}
配置修改完成之后 終端運(yùn)行 npm install 安裝依賴。
接著在目錄下創(chuàng)建文件夾 src及文件等,這是我的目錄結(jié)構(gòu)
對(duì)應(yīng)文件內(nèi)容src/main.vue
<template> <div v-if='visible' class='sever-toast'> <span >{{msg}}</span> </div></template><script>export default { name:'sever-toast', data(){ return { visible:false, msg:’默認(rèn)值’, duration:’3000’, } }, methods:{ close(){ setTimeout(() => { this.visible = false; }, this.duration); } }, mounted(){ }}</script><style > .sever-toast{ display: flex; justify-content: center; align-items: center; height: 100%; position: fixed; top:0; bottom:0; left:0; right:0; } .toast-msg{ color: #ffffff; background:rgba(0,0,0,0.5); padding:0.3rem; border-radius: 0.1rem; font-size: 0.34rem; }</style>
src/main.js
import Vue from ’vue’;import Main from ’./main.vue’let MmToast = Vue.extend(Main);let instance ;const Toast = function(options) { instance = new MmToast({ data: options }); instance.$mount(); document.body.appendChild(instance.$el); instance.visible = true; return instance.close()}export default Toast
Toast/index.js
import Toast from ’./src/main.js’export default Toast
index.js
import Toast from ’./Toast/index.js’ const install = function(Vue) { Vue.prototype.$toast = Toast}console.log(typeof window !== ’undefined’ , window.Vue)if (typeof window !== ’undefined’ && window.Vue) { install(window.Vue);}export default { install, Toast,}
接下來修改webpack.dev.conf.js
const path = require('path');const webpack = require('webpack');const uglify = require('uglifyjs-webpack-plugin');module.exports = { devtool: ’source-map’, entry: './src/index.js',//入口文件,src目錄下的index.js文件, output: { path: path.resolve(__dirname, ’./dist’),//輸出路徑,就是新建的dist目錄, publicPath: ’/dist/’, filename: ’sever-ui.min.js’, libraryTarget: ’umd’, umdNamedDefine: true }, module: { rules: [{test: /.vue$/,loader: ’vue-loader’ }, {test: /.less$/,use: [ { loader: 'style-loader' }, { loader: 'css-loader' }, { loader: 'less-loader' }] }, {test: /.js$/,exclude: /node_modules|vue/dist|vue-router/|vue-loader/|vue-hot-reload-api//,loader: ’babel-loader’ }, {test: /.(png|jpg|gif|ttf|svg|woff|eot)$/,loader: ’url-loader’,query: { limit: 30000, name: ’[name].[ext]?[hash]’} } ] }, plugins: [ new webpack.DefinePlugin({ 'process.env': {NODE_ENV: JSON.stringify('production') } }) ]}
好了 一個(gè)簡單的toast組件已經(jīng)完成了接下來是打包 執(zhí)行 npm run build 生成文件
接著修改package.json
'main':'./dist/sever-ui.min.js',
然后我們就可以上傳到npm了執(zhí)行
npm loginnpm publish
接下來讓我們看看效果
npm install sever-ui
引入
<template> <div class='home'> <div @click='Toast()'>點(diǎn)擊Toast</div> </div></template><script>export default { name: ’Home’, components: { }, methods:{ Toast(){ this.$toast({msg:’哈哈哈哈哈哈’}) } }}</script>
修改
優(yōu)化
只是一個(gè)toast感覺直接輸入內(nèi)容,所以做了一下修改main.js
import Vue from ’vue’;import Main from ’./main.vue’let MmToast = Vue.extend(Main);let instance ;const Toast = function(options) { if( typeof options === ’string’){ options = { msg:options } } instance = new MmToast({ data: options }); instance.$mount(); document.body.appendChild(instance.$el); instance.visible = true; return instance.close()}export default Toast
這樣 就可以直接使用 this.$toast(’toast內(nèi)容’)
到此這篇關(guān)于vue制作一個(gè)toast組件npm包的文章就介紹到這了,更多相關(guān)vue toast組件npm包內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. React+umi+typeScript創(chuàng)建項(xiàng)目的過程2. XML入門的常見問題(二)3. 無線標(biāo)記語言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁4. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執(zhí)行過程解析5. SharePoint Server 2019新特性介紹6. html清除浮動(dòng)的6種方法示例7. ASP調(diào)用WebService轉(zhuǎn)化成JSON數(shù)據(jù),附j(luò)son.min.asp8. ASP中常用的22個(gè)FSO文件操作函數(shù)整理9. .Net core 的熱插拔機(jī)制的深入探索及卸載問題求救指南10. 讀大數(shù)據(jù)量的XML文件的讀取問題
