vue制作toast組件npm包示例代碼
之前寫了一個(gè)ui組件,但是感覺(jué)沒(méi)必要的東西太多了,所以做了一下優(yōu)化
介紹
之前制作的小組件是用webpack-simple搭建的,但是左思右想感覺(jué)沒(méi)必要的東西太多太多,所以又寫了一個(gè)清潔版的,直接開整
開始
建立一個(gè)空文件夾, 然后直接終端運(yùn)行 npm init
建立完之后會(huì)生成一個(gè) package.json
文件,內(nèi)容如下
注意:name是之后要發(fā)的npm包的名字 不要重名,建議去npm先搜一下有沒(méi)有在取
接下來(lái)對(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 class="toast-msg" >{{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, }
接下來(lái)修改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è)簡(jiǎn)單的toast組件已經(jīng)完成了
接下來(lái)是打包 執(zhí)行 npm run build
生成文件
接著修改package.json
"main":"./dist/sever-ui.min.js",
然后我們就可以上傳到npm了
執(zhí)行
npm login npm publish
接下來(lái)讓我們看看效果
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感覺(jué)直接輸入內(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)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)垂直無(wú)限滑動(dòng)日歷組件
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)垂直無(wú)限滑動(dòng)日歷組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04VueX學(xué)習(xí)之modules和namespacedVueX詳細(xì)教程
這篇文章主要為大家介紹了VueX學(xué)習(xí)之modules和namespacedVueX詳細(xì)教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06element-ui中的select下拉列表設(shè)置默認(rèn)值方法
今天小編就為大家分享一篇element-ui中的select下拉列表設(shè)置默認(rèn)值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08關(guān)于uniapp的高級(jí)表單組件mosowe-form
這篇文章主要介紹了關(guān)于uniapp的高級(jí)表單組件mosowe-form,由于一些表單標(biāo)簽改來(lái)改去比較繁瑣,重復(fù)性很多,且樣式布局啥的幾乎萬(wàn)變不離其中,為了偷懶,開發(fā)了mosowe-form及mosowe-table兩款高級(jí)組件,需要的朋友可以參考下2023-04-04