uniapp vue3 + Uview-push 安装使用

时间:2025-01-19 15:25:45

一 , 版本支持   

               Uview 支持vue2    

               Uview - push  支持 vue3

二 , 安装方法

1,首先在uniapp 创建一个基础页面 , 不需要做任何配置(vue3的)

2,找到    uview-plus3.0重磅发布,全面的Vue3移动组件库。 - DCloud 插件市场Uview - push 的官网   点击使用插件安装  并选择  自己刚刚创建的项目

      uview-plus3.0重磅发布,全面的Vue3移动组件库。 - DCloud 插件市场

 

 3,开始各种安装插件 

(1)先看看自己的项目有没有  

文件    没有的话  

在终端执行 
     npm init -y                       安装  
     npm install uview-plus            安装 Uview - push
     npm update uview-plus             更新 Uview - push


然后安装 scss
    // 安装sass
    npm i sass -D

    // 安装sass-loader,注意需要版本10,否则可能会导致vue与sass的兼容问题而报错
    npm i sass-loader@10 -D


安装其他的 配置项

      // 如果您的项目是HX创建的,根目录又没有文件的话,请先执行如下命令:
      // npm init -y

      // 安装
      npm install uview-plus
      npm install dayjs
      npm install clipboard

4, 开始在各种配置项

<script>
	export default {
		onLaunch: function() {
			('App Launch')
		},
		onShow: function() {
			('App Show')
		},
		onHide: function() {
			('App Hide')
		}
	}
</script>
<style lang="scss">
	/* 注意要写在第一行,同时给style标签加入lang="scss"属性 */
	@import "@/uni_modules/uview-plus/";
</style>

import App from './App'

// #ifndef VUE3
import Vue from 'vue'
 = false
 = 'app'


// 
import uviewPlus from 'uview-plus'

// #ifdef VUE3
import { createSSRApp } from 'vue'
export function createApp() {
  const app = createSSRApp(App)
  (uviewPlus)
  return {
    app
  }
}
// #endif

try {
  function isPromise(obj) {
    return (
      !!obj &&
      (typeof obj === "object" || typeof obj === "function") &&
      typeof  === "function"
    );
  }

  // 统一 vue2 API Promise 化返回格式与 vue3 保持一致
  ({
    returnValue(res) {
      if (!isPromise(res)) {
        return res;
      }
      return new Promise((resolve, reject) => {
        ((res) => {
          if (res[0]) {
            reject(res[0]);
          } else {
            resolve(res[1]);
          }
        });
      });
    },
  });
} catch (error) { }

const app = new Vue({
  ...App
})
app.$mount()
// #endif

// #ifdef VUE3
import { createSSRApp } from 'vue'
export function createApp() {
  const app = createSSRApp(App)
  return {
    app
  }
}
// #endif

pages,json

{
	"easycom": {
			// 注意一定要放在custom里,否则无效,/question/131175
			"custom": {  
		        "^u-(.*)": "uview-plus/components/u-$1/u-$" 
			}
		},
	
	"pages": [ //pages数组中第一项表示应用启动页,参考:/collocation/pages
		{
			"path": "pages/index/index",
			"style": {
				"navigationBarTitleText": "uni-app"
			}
		}
	],
	"globalStyle": {
		"navigationBarTextStyle": "black",
		"navigationBarTitleText": "uni-app",
		"navigationBarBackgroundColor": "#F8F8F8",
		"backgroundColor": "#F8F8F8"
	},
	"uniIdRouter": {}
}


// /* 行为相关颜色 */
$uni-color-primary: #007aff;
$uni-color-success: #4cd964;
$uni-color-warning: #f0ad4e;
$uni-color-error: #dd524d;

/* 文字基本颜色 */
$uni-text-color:#333;//基本色
$uni-text-color-inverse:#fff;//反色
$uni-text-color-grey:#999;//辅助灰色,如加载更多的提示信息
$uni-text-color-placeholder: #808080;
$uni-text-color-disable:#c0c0c0;

/* 背景颜色 */
$uni-bg-color:#ffffff;
$uni-bg-color-grey:#f8f8f8;
$uni-bg-color-hover:#f1f1f1;//点击状态颜色
$uni-bg-color-mask:rgba(0, 0, 0, 0.4);//遮罩颜色

/* 边框颜色 */
$uni-border-color:#c8c7cc;

/* 尺寸变量 */

/* 文字尺寸 */
$uni-font-size-sm:12px;
$uni-font-size-base:14px;
$uni-font-size-lg:16;

/* 图片尺寸 */
$uni-img-size-sm:20px;
$uni-img-size-base:26px;
$uni-img-size-lg:40px;

/* Border Radius */
$uni-border-radius-sm: 2px;
$uni-border-radius-base: 3px;
$uni-border-radius-lg: 6px;
$uni-border-radius-circle: 50%;

/* 水平间距 */
$uni-spacing-row-sm: 5px;
$uni-spacing-row-base: 10px;
$uni-spacing-row-lg: 15px;

/* 垂直间距 */
$uni-spacing-col-sm: 4px;
$uni-spacing-col-base: 8px;
$uni-spacing-col-lg: 12px;

/* 透明度 */
$uni-opacity-disabled: 0.3; // 组件禁用态的透明度

/* 文章场景相关 */
$uni-color-title: #2C405A; // 文章标题颜色
$uni-font-size-title:20px;
$uni-color-subtitle: #555555; // 二级标题颜色
$uni-font-size-subtitle:26px;
$uni-color-paragraph: #3F536E; // 文章段落颜色
$uni-font-size-paragraph:15px;
@import '@/uni_modules/uview-plus/';

没有     这个文件的话  创建一个  在里边写入一些配置项

import { defineConfig } from "vite";
import uni from "@dcloudio/vite-plugin-uni";
// import commonjs from '@rollup/plugin-commonjs'

/**
 * @type {import('vite').UserConfig}
 */

export default defineConfig({
  build: {
    sourcemap: false, // App,小程序端源码调试,需要在  中主动开启 sourcemap
	rollupOptions: {
	}
  },

  plugins: [
	// commonjs(),
	uni()
  ],
});

pages /    测试练习 

<template>
	<view style="padding: 20px;">
		<u-button type="primary" text="确定"></u-button>
		<u-button type="primary" :plain="true" text="镂空"></u-button>
		<u-button type="primary" :plain="true" :hairline="true" text="细边"></u-button>
		<u-button type="primary" :disabled="disabled" text="禁用"></u-button>
		<u-button type="primary" loading loadingText="加载中"></u-button>
		<u-button type="primary" icon="map" text="图标按钮"></u-button>
		<u-button type="primary" shape="circle" text="按钮形状"></u-button>
		<u-button text="渐变色按钮" color="linear-gradient(to right, rgb(66, 83, 216), rgb(213, 51, 186))"></u-button>
		<u-button type="primary" size="small" text="大小尺寸"></u-button>
	</view>
</template>

<script>
export default {
	data() {
		return {
			disabled: true
		};
	}
};
</script>

 图片演示