亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決vue自定義全局消息框組件問題

 更新時間:2019年11月22日 15:17:19   作者:一只沒有感情的小殺手  
這篇文章主要介紹了vue自定義全局消息框組件問題及解決方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下

1.發(fā)現(xiàn)問題

在進行移動端適配的時候,為了在各個型號的設(shè)備上能夠更好的提現(xiàn)結(jié)構(gòu)排版,決定采用rem布局。采用rem布局的時候html的字體font-size是有一個標(biāo)準(zhǔn)的。我這邊用的是750px的設(shè)計稿,就采用1rem = 100px。 

在使用的過程中會用到一些第三方UI組件,而第三方UI組件是以px單位為標(biāo)準(zhǔn)的。

使用時發(fā)現(xiàn):本來應(yīng)該細(xì)長的提示語句變得很大!

最后發(fā)現(xiàn)可能是因為這個icon是繼承了html設(shè)定的font-size,嘗試加一些樣式上去還是無效。(如果rem布局上有直接更改第三方組件樣式成功的小伙伴歡迎告訴我喲?。?/p>

2.解決問題

有一種方法是可以可以用 px2rem-loader 插件可以將第三方ui庫的px轉(zhuǎn)換成rem單位,我們在寫樣式的時候用px,這個插件會幫我們轉(zhuǎn)換為rem單位。(因為暫時只是一個提示框遇到這樣的問題,不想大費周章,所以決定暫時不用,以后再用吧嘿嘿?。?br />

自己寫小組件,在網(wǎng)上沖浪了一會,選了幾個小demo實現(xiàn)可以了下,確實比較好?。ú捎眠@個方法!)

3.自定義全局消息組件

大概效果有點模仿 element-ui 中的提示樣式,反正最后效果圖如下:

vue-cli3中component下新建message文件夾,里面再建如下:

Message.vue源代碼如下:

<template>
 <transition name="fade"> <!--這個是動畫的過渡效果-->
 <div class="message" :class="type" v-if="visible">
  <div class="content">
  <i class="icon-type iconfont" :class="'icon-'+type"></i>
  {{content}}
  <i v-if="hasClose" class="btn-close iconfont icon-close" @click="visible=false"></i>
  </div>
 </div>
 </transition>
</template>
 
<script>
export default {
 name: 'Message.vue',
 data () {
 return {
  content: '',
  time: 3000,
  visible: false,
  type: 'info', // 'info','warning','error','success'
  hasClose: false 
 }
 },
 mounted () {
 this.close()
 },
 methods: {
 close () {
  window.setTimeout(() => {
  this.visible = false
  }, this.time)
 }
 }
}
</script>
 
<style scoped lang="scss">
 /* 動畫效果 淡入淡出 */
 .fade-enter-active, .fade-leave-active{
 transition: all 0.5s ease;
 }
 .fade-enter, .fade-leave-active{
 opacity: 0;
 }
 /* 不同的提示語的樣式 */
 .info, .icon-info{
 background-color: #DDDDDD;/*#f0f9eb*/
 color: #909399;
 }
 .success, .icon-success{
 background-color:#f0f9eb;
 color: #67C23A;
 }
 .warning, .icon-warning{
 background-color: #fdf6ec;
 color: #e6a23c;
 }
 .error, .icon-error{
 background-color: #fef0f0;
 color: #f56c6c;
 }
 .message {
 position: fixed;
 left: 50%;
 top: 10%;
 transform: translate(-50%, -50%);
 width:300px;
 height:30px;
 line-height: 30px;
 font-size: 16px;
 padding: 10px;
 border-radius: 5px;
 .content{
  width:100%;
  height:100%;
  text-align:left;
  .icon-type{
  margin:0 10px 0 30px;
  }
  .btn-close{
  font-size:20px;
  margin:0 0 0 70px;
  color:#ccc;
  }
 }
 }
 
</style>

index.js源代碼如下:

給Vue添加$my_message方法,判斷參數(shù),使用 $mount() 給組件手動掛載參數(shù),然后將組件插入頁面中

import Vue from 'vue'
import Message from './Message.vue'
 
const MessageBox = Vue.extend(Message)
 
Message.install = function (options, type) {
 if (options === undefined || options === null) {
 options = {
  content: ''
 }
 } else if (typeof options === 'string' || typeof options === 'number') {
 options = {
  content: options
 }
 if (type !== undefined && options !== null) {
  options.type = type
 }
 }
 
 let instance = new MessageBox({
 data: options
 }).$mount()
 
 document.body.appendChild(instance.$el)
 
 Vue.nextTick(() => {
 instance.visible = true
 })
}
 
export default Message

main.js中:

// 在main.js里面全局引入 自定義的全局消息框組件
import Message from './components/message'
Vue.prototype.$my_message = Message.install

頁面中調(diào)用:

this.$my_message('你這個大笨豬吼吼吼!');
this.$my_message('你這個大笨豬吼吼吼!','success');
this.$my_message({
 content:'服務(wù)器連接失??!', // 彈出的文字內(nèi)容
 time:5000,     // 彈出后多久消失
 type:'success',   // 彈出的消息類型
 hasClose:true,   // 讓按鈕可以被使用,默認(rèn)按鈕是false不可以使用的
 
});

4.注意事項

本Demo中彈出的提示語句中的小圖標(biāo)是iconfont里面的。

總結(jié)

以上所述是小編給大家介紹的解決vue自定義全局消息框組件問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • 使用Element進行前端開發(fā)的詳細(xì)圖文教程

    使用Element進行前端開發(fā)的詳細(xì)圖文教程

    眾所周知Element是一套Vue.js后臺組件庫,它能夠幫助你更輕松更快速地開發(fā)后臺項目,下面這篇文章主要給大家介紹了關(guān)于使用Element進行前端開發(fā)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue實現(xiàn)登陸登出的實現(xiàn)示例

    vue實現(xiàn)登陸登出的實現(xiàn)示例

    本篇文章主要介紹了vue實現(xiàn)登陸登出的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • VUE中的打包刪除文件、圖片的HASH碼

    VUE中的打包刪除文件、圖片的HASH碼

    這篇文章主要介紹了VUE中的打包刪除文件、圖片的HASH碼,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • 關(guān)于VueRouter導(dǎo)入的全過程

    關(guān)于VueRouter導(dǎo)入的全過程

    這篇文章主要介紹了關(guān)于VueRouter導(dǎo)入的全過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue常用傳值方式、父傳子、子傳父及非父子實例分析

    Vue常用傳值方式、父傳子、子傳父及非父子實例分析

    這篇文章主要介紹了Vue常用傳值方式、父傳子、子傳父及非父子,結(jié)合實例形式分析了vue.js常見的傳值方式及相關(guān)操作注意事項,需要的朋友可以參考下
    2020-02-02
  • vue中將html字符串轉(zhuǎn)換成html后遇到的問題小結(jié)

    vue中將html字符串轉(zhuǎn)換成html后遇到的問題小結(jié)

    這篇文章主要介紹了vue中將html字符串轉(zhuǎn)換成html后遇到的問題小結(jié),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-12-12
  • Vue?Router?返回后記住滾動條位置的實現(xiàn)方法

    Vue?Router?返回后記住滾動條位置的實現(xiàn)方法

    使用?Vue?router?創(chuàng)建?SPA(Single?Page?App),往往有這種需求:首頁是列表頁,點擊列表項進入詳情頁,在詳情頁點擊返回首頁后,希望看到的是,首頁不刷新,并且滾動條停留在之前的位置,這篇文章主要介紹了Vue?Router?返回后記住滾動條位置的實現(xiàn)方法,需要的朋友可以參考下
    2023-09-09
  • Vue.js框架實現(xiàn)購物車功能

    Vue.js框架實現(xiàn)購物車功能

    這篇文章主要為大家詳細(xì)介紹了Vue.js框架實現(xiàn)購物車功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue前端img訪問鑒權(quán)后端進行攔截的代碼示例

    vue前端img訪問鑒權(quán)后端進行攔截的代碼示例

    路由攔截是一種在用戶訪問特定頁面之前對其進行攔截和處理的機制,下面這篇文章主要給大家介紹了關(guān)于vue前端img訪問鑒權(quán)后端進行攔截的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • vue3中Vant的使用及說明

    vue3中Vant的使用及說明

    這篇文章主要介紹了vue3中Vant的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01

最新評論