日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue制作toast組件npm包示例代碼

瀏覽:192日期:2022-11-09 14:29:12

之前寫了一個(gè)ui組件,但是感覺沒必要的東西太多了,所以做了一下優(yōu)化

介紹

之前制作的小組件是用webpack-simple搭建的,但是左思右想感覺沒必要的東西太多太多,所以又寫了一個(gè)清潔版的,直接開整

開始

建立一個(gè)空文件夾, 然后直接終端運(yùn)行 npm init建立完之后會(huì)生成一個(gè) package.json 文件,內(nèi)容如下

vue制作toast組件npm包示例代碼

注意: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)

vue制作toast組件npm包示例代碼

對(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è)簡(jiǎn)單的toast組件已經(jīng)完成了接下來是打包 執(zhí)行 npm run build 生成文件

vue制作toast組件npm包示例代碼

接著修改package.json

'main':'./dist/sever-ui.min.js',

然后我們就可以上傳到npm了執(zhí)行

npm loginnpm publish

接下來讓我們看看效果

npm install sever-ui

引入

vue制作toast組件npm包示例代碼

<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>

vue制作toast組件npm包示例代碼

修改

優(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)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品午夜视频| 国产日韩欧美| 好看的亚洲午夜视频在线| 亚洲人亚洲人色久| 日韩一区三区| 欧美日韩中出| 亚洲欧美久久| 在线人成日本视频| 日韩国产专区| 蜜臀精品一区二区三区在线观看| 另类小说一区二区三区| 爽爽淫人综合网网站| 在线人成日本视频| 麻豆精品久久久| 国产日韩一区二区三区在线| 亚洲精品系列| 好看的亚洲午夜视频在线| 91精品1区| 91成人精品| 另类亚洲自拍| 欧美亚洲激情| 国产专区一区| 五月激情久久| 国产亚洲精品久久久久婷婷瑜伽| 天堂久久av| 日本欧洲一区二区| 视频一区二区三区在线| 久久性天堂网| 在线看片日韩| 男人的天堂亚洲一区| 中文在线一区| 午夜欧美视频| 亚洲天堂av资源在线观看| 亚洲精品美女91| 国产精品二区影院| 加勒比视频一区| 欧美13videosex性极品| 激情婷婷综合| 欧美日韩中文一区二区| 国产高清一区二区| 天堂成人国产精品一区| 日本亚洲视频在线| 久久99性xxx老妇胖精品| 福利一区二区免费视频| 极品日韩av| 蜜臀a∨国产成人精品| 国产欧美视频在线| 正在播放日韩精品| 亚洲欧洲一区二区天堂久久| 亚洲18在线| 久久精品国产99| 亚洲欧美日韩专区| 红杏一区二区三区| 欧美日韩尤物久久| 日日夜夜免费精品| 99久久99久久精品国产片果冰| 欧美日韩激情| 国产精品久久久网站| 国产综合色产| 国产欧美在线| 亚洲黄色影院| 一区二区三区四区日本视频| 蜜臀av在线播放一区二区三区| 大香伊人久久精品一区二区| 性欧美长视频| 日韩精品午夜| 国产欧美午夜| 三级一区在线视频先锋| 国产精品日本一区二区三区在线| 日韩在线第七页| 国产精品亲子伦av一区二区三区 | 黄色亚洲免费| 97精品国产一区二区三区| 日韩欧美中文在线观看| 欧美一区二区三区激情视频| 美女视频黄免费的久久| 日日夜夜免费精品视频| 国模 一区 二区 三区| 伊人久久高清| 精品视频一二| 欧美精品导航| 一区二区高清| 丝袜国产日韩另类美女| 日韩在线一二三区| 久久亚洲国产精品一区二区| 国产一区成人| 免费观看在线综合色| 三级一区在线视频先锋| 蜜臀av国产精品久久久久| 免费久久精品视频| 日韩精品成人| 最新国产精品| 日韩国产欧美在线播放| 久久精品国产一区二区| av高清一区| 色吊丝一区二区| 国产精久久一区二区| 精品国产a一区二区三区v免费| 亚洲精品国产精品粉嫩| 午夜精品影院| 亚洲精品高潮| 欧美极品一区二区三区| 在线一区av| 国产手机视频一区二区| 日韩精品视频在线看| 六月丁香综合| 国产精品久久久久久模特| 国产91欧美| 播放一区二区| 亚洲精品韩国| 国产在线看片免费视频在线观看| 国产欧美一区二区色老头| 91p九色成人| 久久精品国产68国产精品亚洲| 综合激情网...| 精品一区不卡| 宅男噜噜噜66国产日韩在线观看| 亚洲精品在线二区| 激情综合五月| 蜜桃视频在线观看一区| www在线观看黄色| 美女久久99| 国产+成+人+亚洲欧洲在线| 久久不卡日韩美女| 久久成人av| 国产精品成人**免费视频| 中文不卡在线| 在线精品观看| 免费高清在线一区| 日韩中文欧美在线| 亚洲免费播放| 手机精品视频在线观看| 精品中文一区| 麻豆9191精品国产| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久电影一区| 中文字幕日韩欧美精品高清在线| 国产农村妇女精品一二区| 蜜臀久久久99精品久久久久久| 久久最新视频| 日本免费在线视频不卡一不卡二| 最新日韩欧美| 日韩精品视频在线看| 欧美午夜三级| 国产成人久久精品麻豆二区 | 亚洲黄色网址| 欧美1区2区3区| 国产精品97| 午夜精品影视国产一区在线麻豆| 日韩国产在线一| 色在线视频观看| 99视频一区| 国产精品调教视频| 国产精品毛片视频| 99成人在线视频| 综合激情视频| 国产一区二区三区免费在线| 亚洲国产成人精品女人| 欧美另类中文字幕| 不卡专区在线| 国产亚洲精品久久久久婷婷瑜伽| 日韩精品视频在线看| 亚洲欧洲美洲av| 麻豆91精品| 岛国av免费在线观看| 久久高清国产| 精品国产一区二区三区av片| 美女网站视频一区| 色老板在线视频一区二区| 视频一区二区三区中文字幕| 成人午夜在线| 日韩av中文字幕一区二区三区| 精精国产xxxx视频在线野外| 日韩高清在线不卡| 久久国产99| 伊人精品一区| 成人午夜精品| 美腿丝袜亚洲一区| 日韩免费精品| 人人爽香蕉精品| 国产一区久久| 欧美精品日日操| 日本激情一区| 国产精品videosex极品| 蜜臀av亚洲一区中文字幕| 成人在线网站| 蜜臀久久精品| 国产精选在线| 国产日韩免费| 日本午夜精品| 国产毛片久久久| 日韩av不卡在线观看| 亚洲精品精选| 日韩成人一级| 91p九色成人| 国产精品久久久久77777丨| 亚洲久久一区| 日韩在线视频一区二区三区| 亚洲精品1区2区| 在线综合亚洲|