ve-plus:基於 vue3.x 桌面端UI組件庫|vue3組件庫

来源:https://www.cnblogs.com/xiaoyan2017/archive/2023/03/02/17170454.html
-Advertisement-
Play Games

VE-Plus 自研輕量級 vue3.js 桌面pc端UI組件庫 經過一個多月的籌劃及開發,今天給大家帶來一款全新的Vue3桌面端UI組件庫VEPlus。新增了35+常用的組件,採用vue3 setup語法糖開發,在使用上和element-ui比較類似,極易快速上手。 ve-plus 致力數據驅動視 ...


VE-Plus 自研輕量級 vue3.js 桌面pc端UI組件庫

經過一個多月的籌劃及開發,今天給大家帶來一款全新的Vue3桌面端UI組件庫VEPlus。新增了35+常用的組件,採用vue3 setup語法糖開發,在使用上和element-ui比較類似,極易快速上手。

ve-plus 致力數據驅動視圖,使用最少的代碼量來實現和element-ui一樣的功能。極少引入外部插件,高定製化及運行速度快。

整合了之前使用vue3.js開發的兩個獨立插件vue3-layer彈窗vue3-scrollbar虛擬滾動條組件。

ve-plus遵循簡潔直觀的UI風格,設計樣式、圖標和文本、元素的位置等保持一致性。

◆ 安裝

npm install ve-plus -S
cnpm install ve-plus -S
yarn add ve-plus

◆ 快速引入

ve-plus 支持全局引入按需引入兩種引入方式。

import { createApp } from "vue"
import App from "./App.vue"
import VEPlus from "ve-plus"

const app = createApp(App)
app.use(VEPlus)
app.mount("#app")
import { Button, Input, Checkbox } from "ve-plus"

<Button type="success" round>按鈕</Button>
<Input v-model="value" />
<Checkbox v-model="checked" label="選中" />

◆ 快速使用

<Button type="primary">Primary</Button>
<Button type="success">Success</Button>
<Button type="warning" round>Warning</Button>
<Button type="primary" icon="ve-icon-filetext" circle></Button>

<Input v-model="inputVal" placeholder="輸入用戶名" />

<Checkbox v-model="checkboxValue" label="Checkbox" />

<Select v-model="selectVal" :options="options" size="large" clearable />

...

<script setup>
    const formRuleRef = ref()
    const rules = ref({
        name: [
            { required: true, message: "請輸入活動名稱", trigger: ["blur", "input"] },
            { min: 3, max: 5, message: "長度在 3 到 5 個字元", trigger: "blur" }
        ],
        region: [
            { required: true, message: "請選擇活動區域", trigger: "change" }
        ],
        type: [
            { type: "array", required: true, message: "請至少選擇一個活動性質", trigger: "change" }
        ],
        resource: [
            { required: true, message: "請選擇活動資源", trigger: "change" }
        ],
        // summary: [
        //     { required: true, message: "請填寫活動詳情", trigger: "blur" }
        // ]
    })
    const handleSubmit = () => {
        formRuleRef.value.validate(valid => {
            if(valid) {
                console.log("submit")
            }else {
                console.log("error...")
                return false
            }
        })
    }
    const handleReset = () => {
        formRuleRef.value.resetFields()
    }
</script>

<template>
    <Form
        ref="formRuleRef"
        :model="formObj"
        labelWidth="80px"
        :rules="rules"
        style="width: 600px;"
    >
        <FormItem label="活動名稱" prop="name">
            <Input v-model="formObj.name" />
        </FormItem>
        <FormItem label="活動區域" prop="region">
            <Select v-model="formObj.region" :options="regionOptions" clearable multiple />
        </FormItem>
        <FormItem label="即時配送" prop="delivery" required message="請勾選即時配送" trigger="change">
            <Switch v-model="formObj.delivery" />
        </FormItem>
        <FormItem label="活動性質" prop="type">
            <CheckboxGroup v-model="formObj.type">
                <Checkbox label="美食/餐廳線上活動" button />
                <Checkbox label="親子主題" button />
                <Checkbox label="品牌推廣" button />
            </CheckboxGroup>
        </FormItem>
        <FormItem label="特殊資源" prop="resource">
            <RadioGroup v-model="formObj.resource">
                <Radio label="線上品牌商贊助" button />
                <Radio label="線下場地免費" button />
            </RadioGroup>
        </FormItem>
        <FormItem label="活動詳情" prop="summary" :rule="[{ required: true, message: "請填寫活動詳情", trigger: "blur" }]">
            <Input v-model="formObj.summary" type="textarea" rows={3} />
        </FormItem>
        <FormItem>
            <Button type="primary" @click="handleSubmit">立即創建</Button>
            <Button @click="handleReset">重置</Button>
        </FormItem>
    </Form>
</template>

<template>
    <Loading v-model="loaded" background="rgba(0,0,0,.75)" spinner="ve-icon-loading" fullscreen="false">
        <template #text><div>載入中...</div></template>
    </Loading>

    <Loading v-model="loaded" text="Loading..." background="rgba(0,0,0,.75)" fullscreen="false" />
</template>

Loading載入組件還支持loading({})函數式調用。

<script setup>
    const handleLoading = () => {
        loading({
            // spinner: "sv-icon-loading",
            text: "Loading...",
            background: "rgba(0,0,0,.75)",
            size: 32,
            // time: 3, // 3s後關閉
            shadeClose: true,
            onOpen: () => {
                console.log("開啟loading")
            },
            onClose: () => {
                console.log("關閉loading")
            }
        })
        // setTimeout(() => {
        //     loading.close()
        // }, 3000)
    }
</script>
<template>
    <Button type="primary" @click="handleLoading">全屏loading</Button>
</template>

支持light/dark兩種主題提示,設置closable屬性可關閉,支持自定義icon圖標

<template>
    <Button @click="Message.success("成功提示")">成功</Button>
    <Button @click="Message({title: "警告提示", type: "warning"})">警告</Button>
    <Button @click="Message.danger("錯誤提示")">錯誤</Button>
    <Button @click="Message.info("消息提示")">消息</Button>
</template>

<script setup>
    // 設置多選
    const tableToggleRef = ref()
    const toggleSelection = (value) => {
        tableToggleRef.value.setCurrentRow(value)
    }
    const toggleTableData = ref([...Array(5)].map((_, i) => ({
        date: `2023-01-${10+i}`,
        name: "Andy",
        state: "Lindon",
        city: "Los Ageles",
        address: `London Park Road no. ${i}`,
        zip: "CA 90036"
    })))
    const toggleTableColumns = ref([
        {type: "selection", width: 100, fixed: true},
        {prop: "date", label: "Date", width: 150, fixed: true},
        {prop: "name", label: "Name", align: "center", width: 120},
        {prop: "state", label: "State", width: 120},
        {prop: "city", label: "City", width: 120},
        {prop: "address", label: "Address", width: 600},
        {prop: "zip", label: "Zip", width: 120},
        {prop: "action", label: "Action", width: 120, fixed: "right"}
    ])
</script>
<template>
    <Table
        ref="tableToggleRef"
        :dataSource="toggleTableData"
        :columns="toggleTableColumns"
        highlight-current-row
        :highlight-multiple="true"
    />
    <Button block @click="toggleSelection([2,4])">Toggle selection status of third and five rows</Button>
    <Button block @click="toggleSelection()">Clear selection</Button>
</template>

好了,這次分享就先到這裡,感興趣的童靴可以安裝體驗一下。如果有好的想法或建議,歡迎一起交流討論哈!

後續還會基於這個ve-plus組件庫開發一個全新的Vue3後臺管理系統,到時也會分享出來。

 

本文為博主原創文章,未經博主允許不得轉載,歡迎大家一起交流 QQ(282310962) wx(xy190310)
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 本文通過幾個簡單的示例,可以快速瞭解Makefile的基本使用方法,適用於編譯我們平時練習所編寫的小量代碼。 1. make命令 Makefile文件內容: all為目標,這裡沒有依賴的文件,這條命令是列印(echo)出“Hello Makefile”這行文字 all: echo "Hello ...
  • 安裝 WSL 2 查看可同時線上安裝的 Linux 發行版名稱 wsl -l -o # 或 wsl --list --online 安裝 WSL 2 命令 wsl --install # 此選項必需,以下選項按需選擇 --no-distribution # 且不安裝發行版 --distributio ...
  • 問題產生: 作者最近在搭建Hadoop+Hive集群時,將NameNode、DataNode、Rm全部部署到一臺物理機上,查詢量較大時連接掛掉。 問題定位: 使用JPS命令查看Metastore服務正常運行,hive2--Runjar掛掉。重啟之後,過段時間又會掛掉。 Linux 內核有個機制叫OO ...
  • 多表查詢(上) 一. 多表關係 在實際應用中,根據需求,設計的表結構之間存在聯繫,聯繫一般分為以下三種 一對多(多對一) 多對多 一對一 1. 一對多(多對一) 案例:部門與員工的關係,一個部門對應多個員工,一個員工對應一個部門。 實現:在多的一方建立外鍵,指向一的一方的主鍵 2. 多對多 案例:學 ...
  • 為了客觀、準確、有效地評估 TDengine 3.0 的性能指標,我們決定使用 TSBS(Time Series Benchmark Suite)作為基準性能測試平臺,針對 DevOps 場景的數據集對 TDengine 3.0 展開整體(包括寫入、查詢、存儲、資源消耗等)性能評估。 ...
  • MySQL中明確查詢語句的執行順序極其重要,瞭解執行順序才不至於犯一些簡單錯誤,例如having 後面是否可以使用 select 中重命名的列名等問題。另外SQL中實際使用最頻繁的就是查詢(Queing),要想寫出高質量、高性能的查詢語句,必須深入地瞭解SQL的邏輯查詢處理順序和機制。 ...
  • 親愛的社區小伙伴們,歷時數月,我們很高興地宣佈,ChunJun 即將迎來 1.16 Release 版本的正式發佈。在新版本中,ChunJun 新增了一批常用功能,進行了多項功能優化和問題修複,併在用戶使用體驗上進行了極大地改善。有17位Contributor 為 ChunJun 提交了多項優化和修 ...
  • 衝突解決 假設你想在應用中使用 some_package 和 other_package,並且它們依賴於不同版本的 url_launcher。於是我們便有了潛在的衝突。避免這種情況的最好方法是 package 的作者在指定依賴項時使用 版本範圍 而非特定版本。 dependencies: url_l ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...