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

詳解vue3+quasar彈窗的幾種方式

 更新時間:2022年08月09日 08:10:22   作者:不知-_  
本文主要介紹了vue3+quasar彈窗的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

1. 鼠標懸浮時的提示(Quasar Tooltip組件)

quasar tooltip組件
當希望將鼠標懸停在目標元素上會顯示提示消息時,可以使用html中的title屬性,但使用title屬性出現(xiàn)的提示框樣式可能并不是我們想要的,這時候可以使用quasar提供的tooltip組件。

可以看到,target默認為true,則會默認將 tooltip 的父元素作為觸發(fā)tooltip的目標,即鼠標經(jīng)過tooltip的父元素時,tooltip就會顯示。

<q-btn color="primary" label="tooltip的父元素" size="24px">
    <q-tooltip>我在這</q-tooltip>
</q-btn>

也可以用String類型指定觸發(fā) tooltip的目標元素。

 <q-btn color="primary" label="tooltip的父元素" size="24px">
        <q-tooltip target=".hover-me">我在這</q-tooltip>
  </q-btn>

  <q-btn class="hover-me" label="tooltip指定的target元素"></q-btn>

其他詳見官方文檔。

2. 點擊某按鈕后出現(xiàn)自定義的彈窗

2.1 點擊某按鈕后出現(xiàn)自定義的彈窗(vue方法)

效果圖
點擊“+”按鈕后彈出選項列表Member子組件,
點擊Member子組件上的按鈕時關閉彈窗。

子組件:

父組件

注意:有需要時可以給子組件Member設置一個z-index的樣式。

知識點

vue 組件 官方文檔:https://staging-cn.vuejs.org/guide/components/registration.html
1、父組件可以使用 props 把數(shù)據(jù)傳給子組件。
2、子組件可以使用 $emit 觸發(fā)父組件的自定義事件。

2.2 點擊某按鈕后出現(xiàn)自定義的彈窗(quasar QDialog組件)

quasar dialog組件通過綁定的值來決定是否顯示該彈窗,值可以使用model-value進行綁定,也可以使用v-model進行綁定。

使用model-value進行綁定時,需要使用:

<q-dialog :model-value="showFlag" persistent>
   ...
</q-dialog>

//or
<q-dialog v-model="showFlag" persistent>
   ...
</q-dialog>

上述同樣的效果也可用以下代碼實現(xiàn):

父組件

<template>
  <div>
     <q-btn round unelevated outline text-color="grey-8" icon="add" class="bg-white" @click="openMember"/>
     <q-dialog :model-value="showFlag" persistent>
          <Member  @close="closeMember"></Member>
     </q-dialog>
   </div>
</template>

<script setup>
import {ref, reactive, watch} from 'vue'
import Member from '../components/Member.vue'

let showFlag = ref(false);

function openMember() {
  showFlag.value = true;
}

function closeMember(list) {
  showFlag.value = false;
  taskInfo.receiverList = list;
}
</script>

<style></style>

子組件Member.vue

<template>
    <div class="q-pa-sm member-list bg-white shadow-1">
      <q-option-group v-model="group" :options="options" color="green" type="checkbox" class="list"/>
      <div class="q-mt-md q-pl-sm row">
        <q-btn class="bg-white q-mr-lg" unelevated outline  text-color="grey-8" label="取消"
               @click="$emit('close')"/>
        <q-btn class="btn-sure" unelevated filled text-color="white" label="確定"
               @click="$emit('close', group)"/>
      </div>
    </div>
</template>

<script setup>
import { ref, watch } from 'vue'
const group = ref([]);
const options = [
  {
    label: '何11',
    value: 'op4'
  },
  {
    label: '何22',
    value: 'op5'
  },
  {
    label: '何33',
    value: 'op6'
  },
  {
    label: '何44',
    value: 'op7'
  },
  {
    label: '何55',
    value: 'op8'
  },
  {
    label: '何66',
    value: 'op9'
  }
];

const emit = defineEmits(['close'])
</script>

<style scoped lang="scss">

.member-list {
  width: 200px;
  border: 1px solid #ffe5e5;
  z-index: 21;
  .list{
    height: 240px;
    overflow: auto;
  }
}

.btn-sure {
  background-color: #9abee8;
}
</style>

使用 dialog 組件還有一個好處就是可以通過transition-show和transition-hide設置彈窗時的動畫,詳見官方文檔。

3. 彈出操作列表/菜單列表(quasar Qmenu組件)

Quasar QMenu組件

<template>
<q-btn label="..." unelevated>
    <q-menu class="bg-grey-10 text-grey-2">
       <q-list>
          <q-item v-close-popup clickable @click="showDate(task.id)">
              <q-item-section>更改截止日期</q-item-section>
          </q-item>
          <q-separator class="bg-grey-5 q-mx-xs"/>
          <q-item v-close-popup clickable @click="deleteConfirm(task.id)">
              <q-item-section>刪除任務</q-item-section>
           </q-item>
        </q-list>
     </q-menu>
</q-btn>
</template>

QMenu同樣有target屬性,其默認為true,會默認將 menu 的父元素作為觸發(fā)menu的目標,即點擊 menu的父元素時, menu就會顯示。

4. 彈出一個操作確認框(Quasar Dialog插件)

quasar Dialog插件能實現(xiàn)類似html的window.confirm()的功能。

使用前需先安裝和引入,具體教程見官網(wǎng)。

以下截圖僅展示在Vite/Vue CLI項目中的使用:

使用示例:

<script setup>
import { ref } from "vue"
import { useQuasar } from 'quasar'

const $q = useQuasar()

function deleteUser(index) {
  $q.dialog({
    title: 'Confirm',
    message: '請確認是否刪除該用戶',
    cancel: "取消",
    ok: "確定",
    persistent: true
  }).onOk(() => {
    console.log('>>>> 刪除了用戶' + index)
  }).onCancel(() => {
    console.log('>>>> 取消了刪除用戶操作')
  })
}
</script>

5. 彈出一個提示框(Quasar Notify插件)

如果僅需彈出一個提示消息而不需要用戶進行其他操作,則可使用Quasar 的 Notify插件

同樣需要安裝后才能使用:

使用示例:

<script setup>
import { ref } from "vue"
import { useQuasar } from 'quasar'

const $q = useQuasar()

function doAddUser(newUser) {
  if (newUser.account.trim() && newUser.password.trim()) {
  	
    }
  else {
    $q.notify(
        {
          message: "請輸入賬號和密碼",
          position: "center",
          timeout: 5
        }
    )
  }
}

</script>

6. Quasar QPopupProxy

Quasar QPopupProxy 組件

到此這篇關于詳解vue3+quasar彈窗的幾種方式的文章就介紹到這了,更多相關vue3 quasar 彈窗內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 解決Vue-cli3沒有vue.config.js文件夾及配置vue項目域名的問題

    解決Vue-cli3沒有vue.config.js文件夾及配置vue項目域名的問題

    這篇文章主要介紹了解決Vue-cli3沒有vue.config.js文件夾及配置vue項目域名的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • Vue項目中添加鎖屏功能實現(xiàn)思路

    Vue項目中添加鎖屏功能實現(xiàn)思路

    這篇文章主要介紹了Vue項目中添加鎖屏功能的實現(xiàn)思路,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • vue下使用nginx刷新頁面404的問題解決

    vue下使用nginx刷新頁面404的問題解決

    這篇文章主要介紹了vue下使用nginx刷新頁面404的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • vue頁面加載閃爍問題的解決方法

    vue頁面加載閃爍問題的解決方法

    這篇文章主要介紹了vue頁面加載閃爍問題的解決方法,文中給大家提到了v-if 和 v-show 的區(qū)別,解決vue頁面加載時出現(xiàn){{message}}閃退的兩種方法,感興趣的朋友一起看看吧
    2018-03-03
  • vue3?中使用?jsx?開發(fā)的詳細過程

    vue3?中使用?jsx?開發(fā)的詳細過程

    這篇文章主要介紹了vue3?中使用?jsx?開發(fā),本文著重說一下在使用 .vue 文件和 .jsx 文件在使用語法上的差異,需要的朋友可以參考下
    2022-09-09
  • Vue實現(xiàn)點擊按鈕進行上下頁切換

    Vue實現(xiàn)點擊按鈕進行上下頁切換

    這篇文章主要介紹了Vue實現(xiàn)點擊按鈕進行上下頁的切換,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • vue將某個組件打包成js并在其他項目使用

    vue將某個組件打包成js并在其他項目使用

    這篇文章主要給大家介紹了關于vue將某個組件打包成js并在其他項目使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • vue中使用極驗驗證碼的方法(附demo)

    vue中使用極驗驗證碼的方法(附demo)

    這篇文章主要介紹了vue中使用極驗驗證碼的方法(附demo)本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • vue如何實現(xiàn)拖動圖片進行排序Vue.Draggable

    vue如何實現(xiàn)拖動圖片進行排序Vue.Draggable

    這篇文章主要介紹了vue如何實現(xiàn)拖動圖片進行排序Vue.Draggable,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue3的watch用法以及和vue2中watch的區(qū)別

    vue3的watch用法以及和vue2中watch的區(qū)別

    這篇文章主要介紹了vue3的watch用法以及和vue2中watch的區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04

最新評論