注释
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | |||||||
|  | .vite/ | ||||||
|  | .hbuilderx/ | ||||||
|  | unpackage/ | ||||||
							
								
								
									
										123
									
								
								App.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,123 @@ | |||||||
|  | <script> | ||||||
|  | 	import {mapState,mapMutations} from 'vuex' | ||||||
|  | 	export default { | ||||||
|  | 		onLaunch: function() { | ||||||
|  | 			let that = this; | ||||||
|  | 			console.log('App Launch') | ||||||
|  | 			// #ifdef MP-WEIXIN  | ||||||
|  | 			uni.login({ | ||||||
|  | 				provider: 'weixin', | ||||||
|  | 				success(resLogin) { | ||||||
|  | 					if (resLogin.errMsg === "login:ok") { | ||||||
|  | 						// 获取jsCode成功,通过jsCode调用微信api获取用户openId | ||||||
|  | 						console.log(resLogin) | ||||||
|  | 						that.$ajax("Demo/test",{code:resLogin.code}) | ||||||
|  | 							.then(res=>{ | ||||||
|  | 								if (res.code == 200) { | ||||||
|  | 									that.saveOpenIdSession(res.data) | ||||||
|  | 								} | ||||||
|  | 							}) | ||||||
|  | 						return | ||||||
|  | 					} | ||||||
|  | 				}, | ||||||
|  | 				fail() { | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						title: '获取用户信息失败,请重试', | ||||||
|  | 						icon: 'none', | ||||||
|  | 						duration: 2000 | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 			// #endif | ||||||
|  | 		}, | ||||||
|  | 		onShow: function() { | ||||||
|  | 			console.log('App Show') | ||||||
|  | 		}, | ||||||
|  | 		onHide: function() { | ||||||
|  | 			console.log('App Hide') | ||||||
|  | 			uni.request({ | ||||||
|  |  | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		methods:{ | ||||||
|  | 			...mapMutations(['saveOpenIdSession']) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  | 	/* #ifndef APP-PLUS-NVUE */ | ||||||
|  | 	/* uni.css - 通用组件、模板样式库,可以当作一套ui库应用 */ | ||||||
|  | 	@import './common/uni.css'; | ||||||
|  |  | ||||||
|  | 	/* H5 兼容 pc 所需 */ | ||||||
|  | 	/* #ifdef H5 */ | ||||||
|  | 	@media screen and (min-width: 768px) { | ||||||
|  | 		body { | ||||||
|  | 			overflow-y: scroll; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* 顶栏通栏样式 */ | ||||||
|  | 	/* .uni-top-window { | ||||||
|  | 		    left: 0; | ||||||
|  | 		    right: 0; | ||||||
|  | 		} */ | ||||||
|  |  | ||||||
|  | 	uni-page-body { | ||||||
|  | 		background-color: #F5F5F5 !important; | ||||||
|  | 		min-height: 100% !important; | ||||||
|  | 		height: auto !important; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-top-window uni-tabbar .uni-tabbar { | ||||||
|  | 		background-color: #fff !important; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-app--showleftwindow .hideOnPc { | ||||||
|  | 		display: none !important; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  |  | ||||||
|  | 	/* 以下样式用于 hello uni-app 演示所需 */ | ||||||
|  | 	page { | ||||||
|  | 		background-color: #efeff4; | ||||||
|  | 		height: 100%; | ||||||
|  | 		font-size: 28rpx; | ||||||
|  | 		/* line-height: 1.8; */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.fix-pc-padding { | ||||||
|  | 		padding: 0 50px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-header-logo { | ||||||
|  | 		padding: 30rpx; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		align-items: center; | ||||||
|  | 		margin-top: 10rpx; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-header-image { | ||||||
|  | 		width: 100px; | ||||||
|  | 		height: 100px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-hello-text { | ||||||
|  | 		color: #7A7E83; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-hello-addfile { | ||||||
|  | 		text-align: center; | ||||||
|  | 		line-height: 300rpx; | ||||||
|  | 		background: #FFF; | ||||||
|  | 		padding: 50rpx; | ||||||
|  | 		margin-top: 10px; | ||||||
|  | 		font-size: 38rpx; | ||||||
|  | 		color: #808080; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif*/ | ||||||
|  | </style> | ||||||
							
								
								
									
										37
									
								
								common/ajax.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,37 @@ | |||||||
|  | // ajax.js | ||||||
|  |  | ||||||
|  | // 引入 uni-ajax 模块 | ||||||
|  | import ajax from '@/uni_modules/u-ajax' | ||||||
|  |  | ||||||
|  | // 创建请求实例 | ||||||
|  | const instance = ajax.create({ | ||||||
|  |   // 初始配置 | ||||||
|  |   baseURL: 'https://dev.xixingwl.cn/api' | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | // 添加请求拦截器 | ||||||
|  | instance.interceptors.request.use( | ||||||
|  |   config => { | ||||||
|  |     // 在发送请求前做些什么 | ||||||
|  |     return config | ||||||
|  |   }, | ||||||
|  |   error => { | ||||||
|  |     // 对请求错误做些什么 | ||||||
|  |     return Promise.reject(error) | ||||||
|  |   } | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // 添加响应拦截器 | ||||||
|  | instance.interceptors.response.use( | ||||||
|  |   response => { | ||||||
|  |     // 对响应数据做些什么 | ||||||
|  |     return response | ||||||
|  |   }, | ||||||
|  |   error => { | ||||||
|  |     // 对响应错误做些什么 | ||||||
|  |     return Promise.reject(error) | ||||||
|  |   } | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // 导出 create 创建后的实例 | ||||||
|  | export default instance | ||||||
							
								
								
									
										1458
									
								
								common/uni.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										20
									
								
								index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,20 @@ | |||||||
|  | <!DOCTYPE html> | ||||||
|  | <html lang="en"> | ||||||
|  |   <head> | ||||||
|  |     <meta charset="UTF-8" /> | ||||||
|  |     <script> | ||||||
|  |       var coverSupport = 'CSS' in window && typeof CSS.supports === 'function' && (CSS.supports('top: env(a)') || | ||||||
|  |         CSS.supports('top: constant(a)')) | ||||||
|  |       document.write( | ||||||
|  |         '<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0' + | ||||||
|  |         (coverSupport ? ', viewport-fit=cover' : '') + '" />') | ||||||
|  |     </script> | ||||||
|  |     <title></title> | ||||||
|  |     <!--preload-links--> | ||||||
|  |     <!--app-context--> | ||||||
|  |   </head> | ||||||
|  |   <body> | ||||||
|  |     <div id="app"><!--app-html--></div> | ||||||
|  |     <script type="module" src="/main.js"></script> | ||||||
|  |   </body> | ||||||
|  | </html> | ||||||
							
								
								
									
										33
									
								
								main.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,33 @@ | |||||||
|  | import App from './App' | ||||||
|  | import ajax from '@/common/ajax.js' // 路径需根据项目实际情况 | ||||||
|  | import store from './store' | ||||||
|  | // #ifndef VUE3 | ||||||
|  | import Vue from 'vue' | ||||||
|  | Vue.config.productionTip = false | ||||||
|  | // Vue2:挂载在 Vue 原型链上,则通过 this.$ajax 调用 | ||||||
|  | Vue.prototype.$ajax = ajax | ||||||
|  | App.mpType = 'app' | ||||||
|  | const app = new Vue({ | ||||||
|  | 	...App | ||||||
|  | }) | ||||||
|  | app.$mount() | ||||||
|  | // #endif | ||||||
|  |  | ||||||
|  | // #ifdef VUE3 | ||||||
|  | import { | ||||||
|  | 	createSSRApp | ||||||
|  | } from 'vue' | ||||||
|  | export function createApp() { | ||||||
|  | 	const app = createSSRApp(App) | ||||||
|  | 	app.use(store) | ||||||
|  | 	// Vue3 (Options API):挂载在当前应用上(app 为 createSSRApp 后的应用),也是通过 this.$ajax 调用 | ||||||
|  | 	// 我们在写 Vue3 时更推荐用 Composition API,即不挂载在实例上 | ||||||
|  | 	app.config.globalProperties.$ajax = ajax | ||||||
|  | 	// 如果你在项目中有用到 nvue 页面,是无法通过 this.$ajax 调用 | ||||||
|  | 	// 需要将请求方法添加到 uni 对象上,然后通过 uni.$ajax 调用 | ||||||
|  | 	uni.$ajax = ajax | ||||||
|  | 	return { | ||||||
|  | 		app | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | // #endif | ||||||
							
								
								
									
										80
									
								
								manifest.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,80 @@ | |||||||
|  | { | ||||||
|  |     "name" : "AnHanNET", | ||||||
|  |     "appid" : "__UNI__5556765", | ||||||
|  |     "description" : "", | ||||||
|  |     "versionName" : "1.0.0", | ||||||
|  |     "versionCode" : "100", | ||||||
|  |     "transformPx" : false, | ||||||
|  |     /* 5+App特有相关 */ | ||||||
|  |     "app-plus" : { | ||||||
|  |         "usingComponents" : true, | ||||||
|  |         "nvueStyleCompiler" : "uni-app", | ||||||
|  |         "compilerVersion" : 3, | ||||||
|  |         "splashscreen" : { | ||||||
|  |             "alwaysShowBeforeRender" : true, | ||||||
|  |             "waiting" : true, | ||||||
|  |             "autoclose" : true, | ||||||
|  |             "delay" : 0 | ||||||
|  |         }, | ||||||
|  |         /* 模块配置 */ | ||||||
|  |         "modules" : {}, | ||||||
|  |         /* 应用发布信息 */ | ||||||
|  |         "distribute" : { | ||||||
|  |             /* android打包配置 */ | ||||||
|  |             "android" : { | ||||||
|  |                 "permissions" : [ | ||||||
|  |                     "<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.VIBRATE\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.READ_LOGS\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>", | ||||||
|  |                     "<uses-feature android:name=\"android.hardware.camera.autofocus\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.CAMERA\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>", | ||||||
|  |                     "<uses-feature android:name=\"android.hardware.camera\"/>", | ||||||
|  |                     "<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             /* ios打包配置 */ | ||||||
|  |             "ios" : {}, | ||||||
|  |             /* SDK配置 */ | ||||||
|  |             "sdkConfigs" : {} | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     /* 快应用特有相关 */ | ||||||
|  |     "quickapp" : {}, | ||||||
|  |     /* 小程序特有相关 */ | ||||||
|  |     "mp-weixin" : { | ||||||
|  |         "appid" : "wxfcd473a3a556b82d", | ||||||
|  |         "setting" : { | ||||||
|  |             "urlCheck" : true, | ||||||
|  |             "postcss" : true, | ||||||
|  |             "minified" : true | ||||||
|  |         }, | ||||||
|  |         "usingComponents" : true, | ||||||
|  |         "permission" : { | ||||||
|  |             "scope.userLocation" : { | ||||||
|  |                 "desc" : "仅用于区域判断" | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "mp-alipay" : { | ||||||
|  |         "usingComponents" : true | ||||||
|  |     }, | ||||||
|  |     "mp-baidu" : { | ||||||
|  |         "usingComponents" : true | ||||||
|  |     }, | ||||||
|  |     "mp-toutiao" : { | ||||||
|  |         "usingComponents" : true | ||||||
|  |     }, | ||||||
|  |     "uniStatistics" : { | ||||||
|  |         "enable" : false | ||||||
|  |     }, | ||||||
|  |     "vueVersion" : "3", | ||||||
|  |     "locale" : "auto" | ||||||
|  | } | ||||||
							
								
								
									
										67
									
								
								pages.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,67 @@ | |||||||
|  | { | ||||||
|  | 	"pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages | ||||||
|  | 		{ | ||||||
|  | 			"path": "pages/loadPage/loadPage", | ||||||
|  | 			"style": { | ||||||
|  | 				"navigationBarTitleText": "四川安汉网络", | ||||||
|  | 				"enablePullDownRefresh": false, | ||||||
|  | 				"navigationStyle": "custom" | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 		}, { | ||||||
|  | 			"path": "pages/tabbar/home/home", | ||||||
|  | 			"style": { | ||||||
|  | 				"navigationBarTitleText": "主页", | ||||||
|  | 				"enablePullDownRefresh": false | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"path": "pages/tabbar/my/my", | ||||||
|  | 			"style": { | ||||||
|  | 				"navigationBarTitleText": "uni-app", | ||||||
|  | 				"enablePullDownRefresh": false, | ||||||
|  | 				"navigationStyle": "custom" | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	    ,{ | ||||||
|  |             "path" : "pages/login/login", | ||||||
|  |             "style" :                                                                                     | ||||||
|  |             { | ||||||
|  |                 "navigationBarTitleText": "", | ||||||
|  |                 "enablePullDownRefresh": false | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  | 	"tabBar": { | ||||||
|  | 		"list": [{ | ||||||
|  | 				"pagePath": "pages/tabbar/home/home", | ||||||
|  | 				"text": "主页", | ||||||
|  | 				"selectedIconPath": "static/tabbar/home_active.png", | ||||||
|  | 				"iconPath": "static/tabbar/home.png" | ||||||
|  | 			}, | ||||||
|  | 			{ | ||||||
|  | 				"pagePath": "pages/tabbar/my/my", | ||||||
|  | 				"text": "我的", | ||||||
|  | 				"selectedIconPath": "static/tabbar/my_active.png", | ||||||
|  | 				"iconPath": "static/tabbar/my.png" | ||||||
|  | 			} | ||||||
|  | 		] | ||||||
|  | 	}, | ||||||
|  | 	"globalStyle": { | ||||||
|  | 		"navigationBarTextStyle": "black", | ||||||
|  | 		"navigationBarTitleText": "演示", | ||||||
|  | 		"navigationBarBackgroundColor": "#F8F8F8", | ||||||
|  | 		"backgroundColor": "#F8F8F8", | ||||||
|  | 		"renderingMode": "seperated", // 仅微信小程序,webrtc 无法正常时尝试强制关闭同层渲染 | ||||||
|  | 		"pageOrientation": "portrait", //横屏配置,全局屏幕旋转设置(仅 APP/微信/QQ小程序),支持 auto / portrait / landscape | ||||||
|  | 		"rpxCalcMaxDeviceWidth": 960, | ||||||
|  | 		"rpxCalcBaseDeviceWidth": 375, | ||||||
|  | 		"rpxCalcIncludeWidth": 750, | ||||||
|  | 		"scrollIndicator":"none", | ||||||
|  | 		"app-plus":{ | ||||||
|  | 			 | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	"uniIdRouter": {} | ||||||
|  | } | ||||||
							
								
								
									
										54
									
								
								pages/loadPage/loadPage.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,54 @@ | |||||||
|  | <template> | ||||||
|  | 	<view class="content"> | ||||||
|  | 		<image class="logo" src="/static/logo.png"></image> | ||||||
|  | 		<view class="text-area"> | ||||||
|  | 			<text class="title">{{title}}</text> | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	export default { | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				title: 'Hello' | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		onLoad() { | ||||||
|  | 			setTimeout(p=>{ uni.reLaunch({ | ||||||
|  | 				url:"/pages/tabbar/home/home" | ||||||
|  | 			})},3000) | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  |  | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  | 	.content { | ||||||
|  | 		display: flex; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.logo { | ||||||
|  | 		height: 200rpx; | ||||||
|  | 		width: 200rpx; | ||||||
|  | 		margin-top: 200rpx; | ||||||
|  | 		margin-left: auto; | ||||||
|  | 		margin-right: auto; | ||||||
|  | 		margin-bottom: 50rpx; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.text-area { | ||||||
|  | 		display: flex; | ||||||
|  | 		justify-content: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.title { | ||||||
|  | 		font-size: 36rpx; | ||||||
|  | 		color: #8f8f94; | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										277
									
								
								pages/login/login.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,277 @@ | |||||||
|  | <template> | ||||||
|  | 	<view | ||||||
|  | 		style="height: 100vh;display: flex;flex-direction: column;align-items: center;justify-content: center;box-sizing: border-box;"> | ||||||
|  | 		<button class="avatar-wrapper" open-type="chooseAvatar" @tap="onChooseAvatar"> | ||||||
|  | 			<image class="avatar" :src="avatarUrl"></image> | ||||||
|  | 		</button> | ||||||
|  | 		<input type="nickname" class="weui-input" placeholder="请输入昵称" /> | ||||||
|  | 		 | ||||||
|  | 		<button type="primary" block open-type="getUserInfo" @getuserinfo="appLoginWx"> | ||||||
|  | 			微信一键登录 | ||||||
|  | 		</button> | ||||||
|  | 		<button v-show="showPhone" type="primary" block open-type="getPhoneNumber" @getphonenumber="getPhone"> | ||||||
|  | 			授权电话 | ||||||
|  | 		</button> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	export default { | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				avatarUrl: 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0', | ||||||
|  | 				openid: "", | ||||||
|  | 				loginstate: "0", | ||||||
|  | 				openid: "", | ||||||
|  | 				userEntity: null, | ||||||
|  | 				terminal: "", | ||||||
|  | 				osVersion: "", | ||||||
|  | 				phoneNumber: "", | ||||||
|  | 				showModal: false, //定义登录弹窗   | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		onLoad: function() {}, | ||||||
|  | 		methods: { | ||||||
|  | 			onChooseAvatar(e) { | ||||||
|  | 				console.log(e) | ||||||
|  | 				const { | ||||||
|  | 					avatarUrl | ||||||
|  | 				} = e.detail | ||||||
|  | 				this.avatarUrl = avatarUrl | ||||||
|  | 			}, | ||||||
|  | 			// 授权获取微信用户信息 | ||||||
|  | 			appLoginWx(res) { | ||||||
|  | 				console.log(res) | ||||||
|  | 				// 获取用户信息成功 | ||||||
|  | 				if (res.detail.errMsg === 'getUserProfile:ok' || res.detail.errMsg === 'getUserInfo:ok') { | ||||||
|  | 					this.userInfo = res.detail.userInfo; | ||||||
|  | 					let _this = this; | ||||||
|  | 					uni.showLoading({ | ||||||
|  | 						title: '获取用户信息...', | ||||||
|  | 						mask: true | ||||||
|  | 					}); | ||||||
|  | 					// 获取jsCode | ||||||
|  | 					uni.login({ | ||||||
|  | 						provider: 'weixin', | ||||||
|  | 						success(resLogin) { | ||||||
|  | 							console.log(resLogin); | ||||||
|  | 							if (resLogin.errMsg === "login:ok") { | ||||||
|  | 								// 获取jsCode成功,通过jsCode调用微信api获取用户openId | ||||||
|  | 								_this.wechatLogin(resLogin.code); | ||||||
|  | 								return | ||||||
|  | 							} | ||||||
|  | 							uni.hideLoading(); | ||||||
|  | 							uni.showToast({ | ||||||
|  | 								title: '获取用户信息失败,请重试', | ||||||
|  | 								icon: 'none', | ||||||
|  | 								duration: 2000 | ||||||
|  | 							}); | ||||||
|  | 						}, | ||||||
|  | 						fail() { | ||||||
|  | 							uni.hideLoading(); | ||||||
|  | 							uni.showToast({ | ||||||
|  | 								title: '获取用户信息失败,请重试', | ||||||
|  | 								icon: 'none', | ||||||
|  | 								duration: 2000 | ||||||
|  | 							}); | ||||||
|  | 						} | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			wechatLogin(wxCode) { | ||||||
|  | 				// 这里一般让后端去调用微信api获取openId等信息,前端调用的话像会多下面这个请求 | ||||||
|  | 				// 因为若果是后端去调用的话,后端拿到微信api返回的openId后可直接去数据库查询判断该用户是否已注册, | ||||||
|  | 				// 如果已经注册了就直接返回注册的用户信息, | ||||||
|  | 				// 如果未注册,则后端需要返回openId、sessionKeyde等信息, | ||||||
|  | 				// 然后前端页面弹出授权获取手机号码的按钮,用户点击后拿到手机号后进行解密后再把信息提交给后台进行注册 | ||||||
|  | 				const params = { | ||||||
|  | 					appid: this.appId, // 小程序的appId(注意需要企业的appId,并且你目前是开发人员,不然后续无法获取到手机号码) | ||||||
|  | 					secret: '***************', // 企业小程序的secret | ||||||
|  | 					js_code: wxCode, // 注意jsCode动态获取的,使用一次后将失效 | ||||||
|  | 					grant_type: 'authorization_code' // 这个参数固定写死 | ||||||
|  | 				} | ||||||
|  | 				that.$ajax('index/index', { | ||||||
|  | 					code: resLogin.code | ||||||
|  | 				}).then(res => { | ||||||
|  | 					console.log(res) | ||||||
|  | 				}) | ||||||
|  | 				// 调用微信api获取openid等信息 | ||||||
|  | 				this.$get('https://api.weixin.qq.com/sns/jscode2session', params).then(res => { | ||||||
|  | 					console.log(res) | ||||||
|  | 					if (res.errcode) { | ||||||
|  | 						console.log('获取openId失败') | ||||||
|  | 						uni.hideLoading(); | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '获取用户信息失败', | ||||||
|  | 							icon: 'none', | ||||||
|  | 							duration: 2000 | ||||||
|  | 						}); | ||||||
|  | 						return | ||||||
|  | 					} | ||||||
|  | 					this.openId = res.openid | ||||||
|  | 					this.sessionKey = res.session_key | ||||||
|  | 					this.unionid = res.unionid | ||||||
|  |  | ||||||
|  | 					// 调用后端接口判断用户是否已注册过 | ||||||
|  | 					this.$post('/login', { | ||||||
|  | 						openId: this.openId | ||||||
|  | 					}).then(res => { | ||||||
|  | 						uni.hideLoading(); | ||||||
|  | 						// 若返回的参数中有token说明已经注册过 | ||||||
|  | 						if (res.status === 200 && res.data.token) { | ||||||
|  | 							uni.showToast({ | ||||||
|  | 								title: '登录成功!', | ||||||
|  | 								duration: 1000 | ||||||
|  | 							}); | ||||||
|  | 							// 缓存用户信息 | ||||||
|  | 							uni.setStorageSync("token", res.data.token); | ||||||
|  | 							uni.setStorageSync("userInfo", res.data); | ||||||
|  | 							// 登录成功返回上一页 | ||||||
|  | 							setTimeout(() => { | ||||||
|  | 								uni.navigateBack({ | ||||||
|  | 									delta: 1 | ||||||
|  | 								}) | ||||||
|  | 							}, 1000) | ||||||
|  | 							return | ||||||
|  | 						} | ||||||
|  | 						// 走到这里说明没有注册过,需要弹出授权获取用户手机号的弹框按钮让用户授权 | ||||||
|  | 						if (res.status == 200) { | ||||||
|  | 							this.showPhone = true | ||||||
|  | 							return | ||||||
|  | 						} | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: res.message, | ||||||
|  | 							icon: 'none', | ||||||
|  | 							duration: 2000 | ||||||
|  | 						}); | ||||||
|  | 					}).catch(() => { | ||||||
|  | 						uni.hideLoading(); | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '登录失败,请稍后重试', | ||||||
|  | 							icon: 'none', | ||||||
|  | 							duration: 2000 | ||||||
|  | 						}); | ||||||
|  | 					}) | ||||||
|  |  | ||||||
|  | 				}).catch(err => { | ||||||
|  | 					console.log(err) | ||||||
|  | 					uni.hideLoading(); | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						title: '获取用户信息失败', | ||||||
|  | 						icon: 'none', | ||||||
|  | 						duration: 2000 | ||||||
|  | 					}); | ||||||
|  | 				}) | ||||||
|  |  | ||||||
|  | 				// 下面注释的就是后端去调用微信api获取用户openId的提供给前端的接口 | ||||||
|  | 				// this.$post('/login', { | ||||||
|  | 				//     jsCode: wxCode | ||||||
|  | 				// }).then(res => { | ||||||
|  | 				//     console.log(res); | ||||||
|  | 				//     uni.hideLoading(); | ||||||
|  | 				//     // 若直接返回token说明已经注册 | ||||||
|  | 				//     if (res.status === 200 && res.data.token) { | ||||||
|  | 				//         uni.showToast({ | ||||||
|  | 				//             title: '登录成功!', | ||||||
|  | 				//             duration: 1000 | ||||||
|  | 				//         }); | ||||||
|  | 				//         uni.setStorageSync("token", res.data.token); | ||||||
|  | 				//         this.saveUserInfo(res.data); | ||||||
|  | 				//         setTimeout(() => { | ||||||
|  | 				//             // this.goTabBar('/pages/index') | ||||||
|  | 				//             uni.navigateBack({ | ||||||
|  | 				//                  delta: 1 | ||||||
|  | 				//             }) | ||||||
|  | 				//         }, 1000) | ||||||
|  | 				//         return | ||||||
|  | 				//     } | ||||||
|  | 				//     if (res.status == 200) { | ||||||
|  | 				//         this.openId = res.data.openid | ||||||
|  | 				//         this.sessionKey = res.data.session_key | ||||||
|  | 				//         this.unionid = res.data.unionid | ||||||
|  | 				//         this.id = res.data.id | ||||||
|  | 				//         this.showPhone = true | ||||||
|  | 				//         return | ||||||
|  | 				//     } | ||||||
|  | 				//     uni.showToast({ | ||||||
|  | 				//         title: res.message, | ||||||
|  | 				//         icon: 'none', | ||||||
|  | 				//         duration: 2000 | ||||||
|  | 				//     }); | ||||||
|  | 				// }).catch(() => { | ||||||
|  | 				//     uni.hideLoading(); | ||||||
|  | 				//     uni.showToast({ | ||||||
|  | 				//         title: '登录失败,请稍后重试', | ||||||
|  | 				//         icon: 'none', | ||||||
|  | 				//         duration: 2000 | ||||||
|  | 				//     }); | ||||||
|  | 				// }) | ||||||
|  | 			}, | ||||||
|  | 			// 授权电话号回调 (这里千万注意:小程序必须要完成 微信认证才能获取到加密的手机号码) | ||||||
|  | 			getPhone(res) { | ||||||
|  | 				console.log(res) | ||||||
|  | 				if (res.detail.errMsg === 'getPhoneNumber:ok') { | ||||||
|  | 					const encryptedData = res.detail.encryptedData | ||||||
|  | 					console.log(123, sessionKey, encryptedData, iv) | ||||||
|  | 					const pc = new WXBizDataCrypt(this.appId, this.sessionKey) | ||||||
|  | 					const data = pc.decryptData(encryptedData, res.detail.iv) // 这里使用解密手机号的方法 | ||||||
|  | 					console.log('解密后 data: ', data.phoneNumber) | ||||||
|  | 					this.phone = data.phoneNumber | ||||||
|  | 					this.showPhone = false | ||||||
|  | 					this.loginHandle() | ||||||
|  | 				} else { | ||||||
|  | 					this.showPhone = false | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						title: '获取手机号失败,请重试', | ||||||
|  | 						icon: 'none', | ||||||
|  | 						duration: 2000 | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			// 用户注册 | ||||||
|  | 			loginHandle() { | ||||||
|  | 				const data = { | ||||||
|  | 					"account": this.phone, | ||||||
|  | 					"icon": this.userInfo.avatarUrl, | ||||||
|  | 					"id": this.id, | ||||||
|  | 					"nickname": this.userInfo.nickName, | ||||||
|  | 					"openId": this.openId, | ||||||
|  | 					"phone": this.phone, | ||||||
|  | 					"unionid": this.unionid | ||||||
|  | 				} | ||||||
|  | 				console.log(data) | ||||||
|  | 				uni.showLoading({ | ||||||
|  | 					title: '登录中...', | ||||||
|  | 					mask: true | ||||||
|  | 				}); | ||||||
|  | 				this.$post('/login/login', data).then(res => { | ||||||
|  | 					console.log(res); | ||||||
|  | 					uni.hideLoading(); | ||||||
|  | 					if (res.status == 200) { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '登录成功!', | ||||||
|  | 							duration: 1000 | ||||||
|  | 						}); | ||||||
|  | 						uni.setStorageSync("token", res.data.token); | ||||||
|  | 						uni.setStorageSync("userInfo", res.data); | ||||||
|  | 						setTimeout(() => { | ||||||
|  | 							uni.navigateBack({ | ||||||
|  | 								delta: 1 | ||||||
|  | 							}) | ||||||
|  | 						}, 1000) | ||||||
|  | 					} else { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: res.message, | ||||||
|  | 							icon: 'none', | ||||||
|  | 							duration: 2000 | ||||||
|  | 						}); | ||||||
|  | 					} | ||||||
|  | 				}); | ||||||
|  | 			}, | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  |  | ||||||
|  | </style> | ||||||
							
								
								
									
										267
									
								
								pages/tabbar/home/home.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,267 @@ | |||||||
|  | <template> | ||||||
|  | 	<view class="warp"> | ||||||
|  | 		<uni-search-bar @confirm="search" v-model="searchValue" @input="input" clearButton="always" cancelButton="none" | ||||||
|  | 			@clear="scan"> | ||||||
|  | 			<template v-slot:clearIcon> | ||||||
|  | 				<uni-icons color="#999999" size="18" type="scan" /> | ||||||
|  | 			</template> | ||||||
|  | 		</uni-search-bar> | ||||||
|  | 		<!-- 个人中心页方格列表数据 --> | ||||||
|  | 		<view class="Grid"> | ||||||
|  | 			<view class="Grid-Item" v-for="item in List" :key="item.id"> | ||||||
|  | 				<view class="GSimg"> | ||||||
|  | 					<image class="Image" :src="item.img"></image> | ||||||
|  | 				</view> | ||||||
|  | 				<view class="GStitle">{{ item.title }}</view> | ||||||
|  | 			</view> | ||||||
|  | 		</view> | ||||||
|  | 		<view class="MsgList"> | ||||||
|  | 			<view class="MlSon" v-for="item in List1" :key="item.id"> | ||||||
|  | 				<view class="MlSonvBox"> | ||||||
|  | 					<view class="SonOfImg"> | ||||||
|  | 						<image class="Img" :src="item.img"></image> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="SonOfName"> | ||||||
|  | 						<view class="SNTop"> | ||||||
|  | 							{{item.title}} | ||||||
|  | 						</view> | ||||||
|  | 						<view class="SNBom"> | ||||||
|  | 							<view class="SBleft"> | ||||||
|  | 								左边信息 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="SBright"> | ||||||
|  | 								右边信息 | ||||||
|  | 							</view> | ||||||
|  | 						</view> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 			</view> | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	export default { | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				searchValue: '123123', | ||||||
|  | 				List: [{ | ||||||
|  | 						id: 1, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: '九宫格布局1' | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: '九宫格布局2' | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 3, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: '九宫格布局3' | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 4, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: '九宫格布局4' | ||||||
|  | 					} | ||||||
|  | 				], | ||||||
|  | 				List1: [{ | ||||||
|  | 						id: 1, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出两行的部分会被作为省略号隐藏,您也可以根据需求将其设为超出一行隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出部分会被作为省略号隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出部分会被作为省略号隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出部分会被作为省略号隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出部分会被作为省略号隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出部分会被作为省略号隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						id: 2, | ||||||
|  | 						img: '../../../static/logo.png', | ||||||
|  | 						title: "这是标题超出部分会被作为省略号隐藏", | ||||||
|  | 						msg: "这是提示信息" | ||||||
|  | 					}, | ||||||
|  | 				] | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		onLoad() { | ||||||
|  | 			//this.$ajax('index') | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			search(res) { | ||||||
|  | 				uni.showToast({ | ||||||
|  | 					title: '搜索:' + res.value, | ||||||
|  | 					icon: 'none' | ||||||
|  | 				}) | ||||||
|  | 			}, | ||||||
|  | 			input(res) { | ||||||
|  | 				console.log('----input:', res) | ||||||
|  | 			}, | ||||||
|  | 			scan(res) { | ||||||
|  | 				// #ifndef H5 | ||||||
|  | 				uni.scanCode({ | ||||||
|  | 					success: function(res) { | ||||||
|  | 						console.log('条码类型:' + res.scanType); | ||||||
|  | 						console.log('条码内容:' + res.result); | ||||||
|  | 					}, | ||||||
|  | 					fail: function() { | ||||||
|  |  | ||||||
|  | 					}, | ||||||
|  | 					complete: function() { | ||||||
|  |  | ||||||
|  | 					} | ||||||
|  | 				}); | ||||||
|  | 				// #endif | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		onBackPress() { | ||||||
|  | 			// #ifdef APP-PLUS | ||||||
|  | 			plus.key.hideSoftKeybord(); | ||||||
|  | 			// #endif | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss"> | ||||||
|  | 	.Grid { | ||||||
|  | 		display: flex; | ||||||
|  | 		flex-wrap: wrap; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		align-content: space-between; | ||||||
|  | 		background: #f7f7f7; | ||||||
|  | 		padding: 10rpx 15rpx; | ||||||
|  |  | ||||||
|  | 		.Grid-Item { | ||||||
|  | 			width: 25%; | ||||||
|  | 			text-align: center; | ||||||
|  | 			border: 1rpx solid #ccc; | ||||||
|  | 			box-sizing: border-box; | ||||||
|  | 			display: flex; | ||||||
|  | 			flex-wrap: wrap; | ||||||
|  | 			justify-content: space-between; | ||||||
|  | 			flex-direction: column; | ||||||
|  | 			align-items: center; | ||||||
|  | 			padding-top: 15rpx; | ||||||
|  | 			padding-bottom: 15rpx; | ||||||
|  |  | ||||||
|  | 			.GSimg { | ||||||
|  | 				width: 96rpx; | ||||||
|  | 				height: 96rpx; | ||||||
|  |  | ||||||
|  | 				.Image { | ||||||
|  | 					width: 96rpx; | ||||||
|  | 					height: 96rpx; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			.GStitle { | ||||||
|  | 				width: 100%; | ||||||
|  | 				height: 34rpx; | ||||||
|  | 				line-height: 34rpx; | ||||||
|  | 				color: #06121e; | ||||||
|  | 				font-size: 24rpx; | ||||||
|  | 				margin-top: 20rpx; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	$max:100%; | ||||||
|  |  | ||||||
|  | 	.MsgList { | ||||||
|  | 		width: 92%; | ||||||
|  | 		margin-left: 4%; | ||||||
|  | 		max-width: 690rpx; | ||||||
|  | 		height: auto; | ||||||
|  |  | ||||||
|  | 		.MlSon { | ||||||
|  | 			border-radius: 12rpx; | ||||||
|  |  | ||||||
|  | 			.MlSonvBox { | ||||||
|  | 				padding: 24rpx 32rpx; | ||||||
|  | 				height: 168rpx; | ||||||
|  | 				display: flex; | ||||||
|  | 				justify-content: space-around; | ||||||
|  | 				background: #fff; | ||||||
|  | 				border: 1px solid red; | ||||||
|  | 				margin-top: 10px; | ||||||
|  |  | ||||||
|  | 				.SonOfImg { | ||||||
|  | 					border: 1px solid red; | ||||||
|  | 					width: 164rpx; | ||||||
|  | 					height: $max; | ||||||
|  | 					border-radius: 12rpx; | ||||||
|  | 					overflow: hidden; | ||||||
|  |  | ||||||
|  | 					.Img { | ||||||
|  | 						width: $max; | ||||||
|  | 						height: $max; | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				.SonOfName { | ||||||
|  | 					width: 428rpx; | ||||||
|  | 					height: $max; | ||||||
|  |  | ||||||
|  | 					.SNTop { | ||||||
|  | 						//这部分是标题 我将其设置为超出两行隐藏掉您可根据需求设置为一行 | ||||||
|  | 						width: $max; | ||||||
|  | 						height: 88rpx; | ||||||
|  | 						text-overflow: -o-ellipsis-lastline; | ||||||
|  | 						overflow: hidden; | ||||||
|  | 						text-overflow: ellipsis; | ||||||
|  | 						display: -webkit-box; | ||||||
|  | 						-webkit-line-clamp: 2; | ||||||
|  | 						line-clamp: 2; | ||||||
|  | 						-webkit-box-orient: vertical; | ||||||
|  | 						line-height: 44rpx; | ||||||
|  | 						color: #06121E; | ||||||
|  | 						font-size: 28rpx; | ||||||
|  | 					} | ||||||
|  |  | ||||||
|  | 					.SNBom { | ||||||
|  | 						width: $max; | ||||||
|  | 						height: 34rpx; | ||||||
|  | 						line-height: 34rpx; | ||||||
|  | 						font-size: 24rpx; | ||||||
|  | 						display: flex; | ||||||
|  | 						justify-content: space-between; | ||||||
|  | 						margin-top: 18rpx; | ||||||
|  |  | ||||||
|  | 						.SBleft { | ||||||
|  | 							//这里预留了底部左右信息的样式处理 | ||||||
|  | 						} | ||||||
|  |  | ||||||
|  | 						.SBright {} | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										189
									
								
								pages/tabbar/my/my.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,189 @@ | |||||||
|  | <template> | ||||||
|  | 	<view> | ||||||
|  | 		<page-head title="view"></page-head> | ||||||
|  | 		<view class="warp" style="margin: 10rpx 15rpx;"> | ||||||
|  | 			<view class="user" style=""> | ||||||
|  | 				<image class="user-avatar" mode="aspectFit" src="../../../static/logo.png"></image> | ||||||
|  | 				<view class="user-info"> | ||||||
|  | 					<h2> 用户昵称 </h2> | ||||||
|  | 					<text> UID 1234567897 </text> | ||||||
|  | 					<text> 用户昵称</text> | ||||||
|  | 				</view> | ||||||
|  | 			</view> | ||||||
|  | 			<view style="padding: 10rpx;"></view> | ||||||
|  | 			<view class="Grid"> | ||||||
|  | 				<view class="Grid-Item"> | ||||||
|  | 					<view class="Grid-Item-1"> | ||||||
|  | 						<view class="GSimg"> | ||||||
|  | 							<image class="Image" src="../../../static/logo.png"></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="GStitle">测试功能</view> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 				<view class="Grid-Item"> | ||||||
|  | 					<view class="Grid-Item-1"> | ||||||
|  | 						<view class="GSimg"> | ||||||
|  | 							<image class="Image" src="../../../static/logo.png"></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="GStitle">测试功能</view> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 				<view class="Grid-Item"> | ||||||
|  | 					<view class="Grid-Item-1"> | ||||||
|  | 						<view class="GSimg"> | ||||||
|  | 							<image class="Image" src="../../../static/logo.png"></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="GStitle">测试功能</view> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 				<view class="Grid-Item"> | ||||||
|  | 					<view class="Grid-Item-1"> | ||||||
|  | 						<view class="GSimg"> | ||||||
|  | 							<image class="Image" src="../../../static/logo.png"></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="GStitle">测试功能</view> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 			</view> | ||||||
|  |  | ||||||
|  | 			<view style="padding: 10rpx;"></view> | ||||||
|  | 			<uni-list style=""> | ||||||
|  | 				<uni-list-item title="列表左侧带略缩图" | ||||||
|  | 					thumb="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" | ||||||
|  | 					thumb-size="sm" rightText="右侧文字" showArrow></uni-list-item> | ||||||
|  | 				<uni-list-item :showExtraIcon="true" :extraIcon="{color: '#4cd964',size: '25',type: 'gear'}" | ||||||
|  | 					title="列表左侧带扩展图标" clickable showArrow> | ||||||
|  | 				</uni-list-item> | ||||||
|  | 				<uni-list-item :showExtraIcon="true" :extraIcon="{color: '#4cd964',size: '25',type: 'gear'}" | ||||||
|  | 					title="列表左侧带扩展图标" clickable showArrow> | ||||||
|  | 				</uni-list-item> | ||||||
|  | 				<uni-list-item :showExtraIcon="true" :extraIcon="{color: '#4cd964',size: '25',type: 'gear'}" | ||||||
|  | 					title="列表左侧带扩展图标" clickable showArrow> | ||||||
|  | 				</uni-list-item> | ||||||
|  | 			</uni-list> | ||||||
|  | 			<view style="padding: 10rpx;"></view> | ||||||
|  | 			<uni-list> | ||||||
|  | 				<uni-list-item title="列表左侧带略缩图" | ||||||
|  | 					thumb="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" | ||||||
|  | 					thumb-size="sm" rightText="右侧文字" showArrow></uni-list-item> | ||||||
|  | 				<uni-list-item :showExtraIcon="true" :extraIcon="{color: '#4cd964',size: '25',type: 'gear'}" title="设置" | ||||||
|  | 					clickable showArrow> | ||||||
|  | 				</uni-list-item> | ||||||
|  | 				<uni-list-item :showExtraIcon="true" :extraIcon="{color: '#4cd964',size: '25',type: 'info'}" title="关于" | ||||||
|  | 					clickable showArrow> | ||||||
|  | 				</uni-list-item> | ||||||
|  | 				<uni-list-item :showExtraIcon="true" :extraIcon="{color: '#ff0000',size: '25',type: 'back'}" title="退出" | ||||||
|  | 					clickable showArrow> | ||||||
|  | 				</uni-list-item> | ||||||
|  | 			</uni-list> | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	import {mapState,mapGetters} from 'vuex' | ||||||
|  | 	export default { | ||||||
|  | 		computed: { | ||||||
|  | 			...mapState({ | ||||||
|  | 				text: state => state.moduleA.text, | ||||||
|  | 				timestamp: state => state.moduleB.timestamp | ||||||
|  | 			}), | ||||||
|  | 			...mapGetters({ | ||||||
|  | 			  isLogin: 'userIsLogin' | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			return {} | ||||||
|  | 		}, | ||||||
|  | 		onLoad(){ | ||||||
|  | 			if (! this.isLogin) { | ||||||
|  | 				uni.redirectTo({ | ||||||
|  | 					url:"/pages/login/login" | ||||||
|  | 				}) | ||||||
|  | 			}		 | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  |  | ||||||
|  | 		}, | ||||||
|  | 		onBackPress() { | ||||||
|  | 			// #ifdef APP-PLUS | ||||||
|  | 			plus.key.hideSoftKeybord(); | ||||||
|  | 			// #endif | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss"> | ||||||
|  | 	.user { | ||||||
|  | 		box-sizing: border-box; | ||||||
|  | 		display: flex; | ||||||
|  | 		flex-wrap: wrap; | ||||||
|  | 		justify-content: flex-start; | ||||||
|  | 		align-items: center; | ||||||
|  | 		padding-top: 180rpx; | ||||||
|  | 		padding-left: 15rpx; | ||||||
|  | 		padding-bottom:25rpx; | ||||||
|  |  | ||||||
|  | 		.user-avatar { | ||||||
|  | 			width: 138rpx; | ||||||
|  | 			height: 138rpx; | ||||||
|  | 			border-radius: 50%; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		.user-info { | ||||||
|  | 			flex: 1; | ||||||
|  | 			display: flex; | ||||||
|  | 			flex-direction: column; | ||||||
|  | 			justify-content: center; | ||||||
|  | 			padding-left: 45rpx; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.Grid { | ||||||
|  | 		display: flex; | ||||||
|  | 		flex-wrap: wrap; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		align-content: space-between; | ||||||
|  | 		background: #f7f7f7; | ||||||
|  |  | ||||||
|  | 		.Grid-Item { | ||||||
|  | 			width: 25%; | ||||||
|  |  | ||||||
|  | 			.Grid-Item-1 { | ||||||
|  | 				margin-left: 10rpx; | ||||||
|  | 				margin-right: 10rpx; | ||||||
|  | 				text-align: center; | ||||||
|  | 				border: 1rpx solid #efeded; | ||||||
|  | 				border-radius: 25rpx; | ||||||
|  | 				box-sizing: border-box; | ||||||
|  | 				display: flex; | ||||||
|  | 				flex-wrap: wrap; | ||||||
|  | 				justify-content: space-around; | ||||||
|  | 				flex-direction: column; | ||||||
|  | 				align-items: center; | ||||||
|  | 				padding-top: 20rpx; | ||||||
|  | 				padding-bottom: 5rpx; | ||||||
|  | 				background-color: #fff; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			.GSimg { | ||||||
|  | 				width: 96rpx; | ||||||
|  | 				height: 96rpx; | ||||||
|  |  | ||||||
|  | 				.Image { | ||||||
|  | 					width: 96rpx; | ||||||
|  | 					height: 96rpx; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			.GStitle { | ||||||
|  | 				width: 100%; | ||||||
|  | 				height: 34rpx; | ||||||
|  | 				line-height: 34rpx; | ||||||
|  | 				color: #06121e; | ||||||
|  | 				font-size: 24rpx; | ||||||
|  | 				margin-top: 10rpx; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										
											BIN
										
									
								
								static/avatar0.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								static/avatar1.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								static/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.9 KiB | 
							
								
								
									
										
											BIN
										
									
								
								static/tabbar/home.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 666 B | 
							
								
								
									
										
											BIN
										
									
								
								static/tabbar/home_active.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 692 B | 
							
								
								
									
										
											BIN
										
									
								
								static/tabbar/my.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 898 B | 
							
								
								
									
										
											BIN
										
									
								
								static/tabbar/my_active.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 930 B | 
							
								
								
									
										
											BIN
										
									
								
								static/uni.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										8
									
								
								store/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,8 @@ | |||||||
|  | // 页面路径:store/index.js | ||||||
|  | import {createStore} from 'vuex' | ||||||
|  | import user from '@/store/modules/user' | ||||||
|  | export default createStore({ | ||||||
|  | 	modules: { | ||||||
|  | 		user, | ||||||
|  | 	} | ||||||
|  | }) | ||||||
							
								
								
									
										0
									
								
								store/modules/common.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										62
									
								
								store/modules/user.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,62 @@ | |||||||
|  | // 子模块moduleB路径:store/modules/moduleB.js | ||||||
|  | export default { | ||||||
|  | 	state: { | ||||||
|  | 		timestamp: 1608820295, //初始时间戳 | ||||||
|  | 		isLogin: false, | ||||||
|  | 		token: uni.getStorageSync('token') || '', | ||||||
|  | 		userinfo: JSON.parse(uni.getStorageSync('userinfo') || '{}'), | ||||||
|  | 		openId: null, | ||||||
|  | 		sessionKey:null, | ||||||
|  | 	}, | ||||||
|  | 	getters: { | ||||||
|  | 		timeString(state) { //时间戳转换后的时间 | ||||||
|  | 			var date = new Date(state.timestamp); | ||||||
|  | 			var year = date.getFullYear(); | ||||||
|  | 			var mon = date.getMonth() + 1; | ||||||
|  | 			var day = date.getDate(); | ||||||
|  | 			var hours = date.getHours(); | ||||||
|  | 			var minu = date.getMinutes(); | ||||||
|  | 			var sec = date.getSeconds(); | ||||||
|  | 			var trMon = mon < 10 ? '0' + mon : mon | ||||||
|  | 			var trDay = day < 10 ? '0' + day : day | ||||||
|  | 			return year + '-' + trMon + '-' + trDay + " " + hours + ":" + minu + ":" + sec; | ||||||
|  | 		}, | ||||||
|  | 		userIsLogin(state){ | ||||||
|  | 			return state.isLogin; | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	mutations: { | ||||||
|  | 		updateTime(state) { //更新当前时间戳 | ||||||
|  | 			state.timestamp = Date.now() | ||||||
|  | 		}, | ||||||
|  | 		// 更新用户信息 | ||||||
|  | 		updateUserInfo(state, userinfo) { | ||||||
|  | 			state.userinfo = userinfo | ||||||
|  | 			this.commit('saveUserInfoToStorge') | ||||||
|  | 		}, | ||||||
|  | 		// 将用户信息持久化存储到本地 | ||||||
|  | 		saveUserInfoToStorge(state) { | ||||||
|  | 			uni.setStorageSync('userinfo', JSON.stringify(state.userinfo)) | ||||||
|  | 		}, | ||||||
|  | 		// 更新 token 字符串 | ||||||
|  | 		updateToken(state, token) { | ||||||
|  | 			state.token = token | ||||||
|  | 			// 调用saveTokenToStorage方法 | ||||||
|  | 			this.commit('saveTokenToStorage') | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		// 将 token 字符串持久化存储到本地 | ||||||
|  | 		saveTokenToStorage(state) { | ||||||
|  | 			uni.setStorageSync('token', state.token) | ||||||
|  | 		}, | ||||||
|  | 		// 将 token 字符串持久化存储到本地 | ||||||
|  | 		saveOpenIdSession(state, res) { | ||||||
|  | 			state.openId = res.openid | ||||||
|  | 			state.sessionKey = res.session_key | ||||||
|  | 			//this.unionid = res.unionid | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	actions: { | ||||||
|  |  | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										76
									
								
								uni.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,76 @@ | |||||||
|  | /** | ||||||
|  |  * 这里是uni-app内置的常用样式变量 | ||||||
|  |  * | ||||||
|  |  * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量 | ||||||
|  |  * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能 | ||||||
|  |  * | ||||||
|  |  * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件 | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /* 颜色变量 */ | ||||||
|  |  | ||||||
|  | /* 行为相关颜色 */ | ||||||
|  | $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:#e5e5e5; | ||||||
|  |  | ||||||
|  | /* 尺寸变量 */ | ||||||
|  |  | ||||||
|  | /* 文字尺寸 */ | ||||||
|  | $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; | ||||||
							
								
								
									
										83
									
								
								uni_modules/u-ajax/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,83 @@ | |||||||
|  | ## ✨ 特性 | ||||||
|  |  | ||||||
|  | - 支持 Promise API | ||||||
|  | - 支持 Typescript 开发 | ||||||
|  | - 拦截请求和响应 | ||||||
|  | - 自定义配置请求实例 | ||||||
|  | - 多种 Method 方法请求 | ||||||
|  | - 支持 RequestTask 操作 | ||||||
|  |  | ||||||
|  | ## 🍟 文档 | ||||||
|  |  | ||||||
|  | **[uniajax.ponjs.com](https://uniajax.ponjs.com)** | ||||||
|  |  | ||||||
|  | ## 🥗 安装 | ||||||
|  |  | ||||||
|  | **插件市场** | ||||||
|  |  | ||||||
|  | 在插件市场右上角选择 `使用HBuilder X 导入插件` 或者 `下载插件ZIP` | ||||||
|  |  | ||||||
|  | **NPM** | ||||||
|  |  | ||||||
|  | ```bash | ||||||
|  | # 如果您的项目是HBuilder X创建的,根目录又没有package.json文件的话,请先执行如下命令: | ||||||
|  | # npm init -y | ||||||
|  |  | ||||||
|  | # 安装 | ||||||
|  | npm install uni-ajax | ||||||
|  |  | ||||||
|  | # 更新 | ||||||
|  | npm update uni-ajax | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## 🥐 实例 | ||||||
|  |  | ||||||
|  | 新建 `ajax.js` 文件(文件名可自定义)用于处理拦截器、接口根地址、默认配置等,详细配置请[查看文档](https://uniajax.ponjs.com/instance/create.html) | ||||||
|  |  | ||||||
|  | ```JavaScript | ||||||
|  | // ajax.js | ||||||
|  |  | ||||||
|  | import ajax from 'uni-ajax'                                 // 引入 uni-ajax 模块 | ||||||
|  |  | ||||||
|  | const instance = ajax.create(config)                        // 创建请求实例 | ||||||
|  |  | ||||||
|  | instance.interceptors.request.use(onFulfilled, onRejected)  // 添加请求拦截器 | ||||||
|  | instance.interceptors.response.use(onFulfilled, onRejected) // 添加响应拦截器 | ||||||
|  |  | ||||||
|  | export default instance                                     // 导出创建后的实例 | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## 🥪 使用 | ||||||
|  |  | ||||||
|  | **请求方法** | ||||||
|  |  | ||||||
|  | ```JavaScript | ||||||
|  | // 常规方法 | ||||||
|  | ajax() | ||||||
|  |  | ||||||
|  | // 请求方法别名 | ||||||
|  | ajax.get() | ||||||
|  | ajax.post() | ||||||
|  | ajax.put() | ||||||
|  | ajax.delete() | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | **RequestTask** | ||||||
|  |  | ||||||
|  | ```JavaScript | ||||||
|  | import ajax, { Fetcher } from 'uni-ajax' | ||||||
|  |  | ||||||
|  | const fetcher = new Fetcher() | ||||||
|  | ajax({ fetcher }) | ||||||
|  |  | ||||||
|  | fetcher.abort()                            // 中断请求任务 | ||||||
|  | const requestTask = await fetcher.source() // 获取请求任务对象 | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | **其他属性方法** | ||||||
|  |  | ||||||
|  | ```JavaScript | ||||||
|  | ajax.defaults       // 全局默认配置 | ||||||
|  | ajax.config         // 当前实例配置 | ||||||
|  | ajax.getURL(config) // 获取实例请求地址 | ||||||
|  | ``` | ||||||
							
								
								
									
										35
									
								
								uni_modules/u-ajax/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,35 @@ | |||||||
|  | ## 2.5.1(2023-01-16) | ||||||
|  | - 精简代码,体积更小,性能提升 | ||||||
|  | - 废弃封装请求任务方法和 xhr 属性 [详情](https://uniajax.ponjs.com/guide/usage#requesttask) | ||||||
|  | - 新增 fetcher 属性获取请求任务 [详情](https://uniajax.ponjs.com/api/config#fetcher) | ||||||
|  | - 移除回调函数属性 success / fail / complete [详情](https://uniajax.ponjs.com/guide/usage#发起请求) | ||||||
|  | ## 2.4.6(2022-12-01) | ||||||
|  | - 新增自定义响应内容类型 CustomResponse [详情](https://uniajax.ponjs.com/guide/typescript#定义类型) | ||||||
|  | - 修改自定义请求配置类型 CustomConfig [详情](https://uniajax.ponjs.com/guide/typescript#定义类型) | ||||||
|  | - 优化插件市场安装引入路径 [详情](https://uniajax.ponjs.com/guide/installation#插件市场) | ||||||
|  | - 优化创建请求类工厂函数 | ||||||
|  |  | ||||||
|  | ## 2.4.5(2022-07-08) | ||||||
|  | - 优化使用拦截器的 Typescript 类型 [详情](https://uniajax.ponjs.com/api#interceptors) | ||||||
|  |  | ||||||
|  | ## 2.4.4(2022-04-01) | ||||||
|  | - 修复 params 参数被转成 JSON 字符串问题 [详情](https://uniajax.ponjs.com/api/config#params) | ||||||
|  |  | ||||||
|  | ## 2.4.3(2022-02-24) | ||||||
|  | - 兼容支付宝小程序不支持 `class extends Promise` 错误 | ||||||
|  | - 去除多余的 defaults 默认值 [详情](https://uniajax.ponjs.com/api#defaults) | ||||||
|  |  | ||||||
|  | ## 2.4.2(2022-02-01) | ||||||
|  | - 修改 params 配置参数 [详情](https://uniajax.ponjs.com/api/config#params) | ||||||
|  | - 新增 query 配置参数 [详情](https://uniajax.ponjs.com/api/config#query) | ||||||
|  | - 优化 create 方法的 TypeScript 参数类型 | ||||||
|  |  | ||||||
|  | ## 2.4.1(2022-01-15) | ||||||
|  | - 全新的获取实例配置机制 [详情](https://uniajax.ponjs.com/guide/instance#实例配置) | ||||||
|  | - 新增全局默认配置 [详情](https://uniajax.ponjs.com/guide/instance#全局配置) | ||||||
|  | - 新增获取请求地址方法 [详情](https://uniajax.ponjs.com/api#geturl) | ||||||
|  | - 去除获取 baseURL 和 origin 属性 | ||||||
|  |  | ||||||
|  | ## 2.4.0(2022-01-15) | ||||||
|  | **全新版本发布** | ||||||
|  | 注意 2.4.x 版本与 2.3.x 以下版本存在些许差异! | ||||||
							
								
								
									
										103
									
								
								uni_modules/u-ajax/js_sdk/index.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,103 @@ | |||||||
|  | export type AnyObject = { [x: string]: any } | ||||||
|  |  | ||||||
|  | export type Data = string | AnyObject | ArrayBuffer | ||||||
|  | export type Method = 'GET' | 'POST' | 'PUT' | 'DELETE' | 'CONNECT' | 'HEAD' | 'OPTIONS' | 'TRACE' | ||||||
|  | export type DataType = 'json' | 'text' | 'html' | ||||||
|  | export type ResponseType = 'text' | 'arraybuffer' | ||||||
|  |  | ||||||
|  | export interface RequestTask { | ||||||
|  |   abort: () => void | ||||||
|  |   onHeadersReceived?: (listener: (header: any) => void) => void | ||||||
|  |   offHeadersReceived?: (listener: (header: any) => void) => void | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface FetcherInstance<T = any> { | ||||||
|  |   resolve: (value: T) => void | ||||||
|  |   reject: (reason?: any) => void | ||||||
|  |   source: () => Promise<T> | ||||||
|  |   abort: () => Promise<void> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface FetcherConstructor { | ||||||
|  |   new <T = RequestTask>(): FetcherInstance<T> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface CustomConfig {} | ||||||
|  |  | ||||||
|  | export interface AjaxRequestConfig extends CustomConfig { | ||||||
|  |   baseURL?: string | ||||||
|  |   url?: string | ||||||
|  |   data?: Data | ||||||
|  |   query?: AnyObject | ||||||
|  |   params?: AnyObject | ||||||
|  |   header?: any | ||||||
|  |   method?: Method | ||||||
|  |   timeout?: number | ||||||
|  |   dataType?: DataType | ||||||
|  |   responseType?: ResponseType | ||||||
|  |   sslVerify?: boolean | ||||||
|  |   withCredentials?: boolean | ||||||
|  |   firstIpv4?: boolean | ||||||
|  |   fetcher?: FetcherInstance | ||||||
|  |   validateStatus?: ((statusCode?: number) => boolean) | null | ||||||
|  |   adapter?: (config: AjaxRequestConfig) => Promise<any> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export type AjaxConfigType = | ||||||
|  |   | AjaxRequestConfig | ||||||
|  |   | (() => AjaxRequestConfig) | ||||||
|  |   | (() => Promise<AjaxRequestConfig>) | ||||||
|  |   | void | ||||||
|  |  | ||||||
|  | export interface AjaxResponse<T = any> { | ||||||
|  |   data: T | ||||||
|  |   statusCode: number | ||||||
|  |   header: any | ||||||
|  |   config: AjaxRequestConfig | ||||||
|  |   errMsg: string | ||||||
|  |   cookies: string[] | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface AjaxInterceptorManager<V> { | ||||||
|  |   use<T = V>(onFulfilled?: (value: V) => T | Promise<T>, onRejected?: (error: any) => any): number | ||||||
|  |   eject(id: number): void | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface CustomResponse<T = any> {} | ||||||
|  |  | ||||||
|  | export type AjaxResult<T> = keyof CustomResponse extends never ? AjaxResponse<T> : CustomResponse<T> | ||||||
|  |  | ||||||
|  | export interface AjaxInvoke { | ||||||
|  |   <T = any, R = AjaxResult<T>>(config?: AjaxRequestConfig): Promise<R> | ||||||
|  |   <T = any, R = AjaxResult<T>>(url?: string, data?: Data, config?: AjaxRequestConfig): Promise<R> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface AjaxInstance<T extends AjaxConfigType> extends AjaxInvoke { | ||||||
|  |   get: AjaxInvoke | ||||||
|  |   post: AjaxInvoke | ||||||
|  |   put: AjaxInvoke | ||||||
|  |   delete: AjaxInvoke | ||||||
|  |   connect: AjaxInvoke | ||||||
|  |   head: AjaxInvoke | ||||||
|  |   options: AjaxInvoke | ||||||
|  |   trace: AjaxInvoke | ||||||
|  |   getURL(config?: AjaxConfigType): Promise<string> | ||||||
|  |   readonly defaults: AjaxRequestConfig | ||||||
|  |   readonly config: T | ||||||
|  |   interceptors: { | ||||||
|  |     request: AjaxInterceptorManager<AjaxRequestConfig> | ||||||
|  |     response: AjaxInterceptorManager<AjaxResponse> | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface AjaxStatic extends AjaxInstance<void> { | ||||||
|  |   create<T extends AjaxConfigType = void>(config?: T): AjaxInstance<T> | ||||||
|  |   Fetcher: FetcherConstructor | ||||||
|  | } | ||||||
|  |  | ||||||
|  | declare const Ajax: AjaxStatic | ||||||
|  | declare const Fetcher: FetcherConstructor | ||||||
|  |  | ||||||
|  | export { Fetcher } | ||||||
|  |  | ||||||
|  | export default Ajax | ||||||
							
								
								
									
										14
									
								
								uni_modules/u-ajax/js_sdk/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | |||||||
|  | import Ajax from './lib/core/Ajax' | ||||||
|  | import Fetcher from './lib/adapters/Fetcher' | ||||||
|  |  | ||||||
|  | const ajax = Ajax() | ||||||
|  |  | ||||||
|  | ajax.create = function create(instanceConfig) { | ||||||
|  |   return Ajax(instanceConfig) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ajax.Fetcher = Fetcher | ||||||
|  |  | ||||||
|  | export { Fetcher } | ||||||
|  |  | ||||||
|  | export default ajax | ||||||
							
								
								
									
										22
									
								
								uni_modules/u-ajax/js_sdk/lib/adapters/Fetcher.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | |||||||
|  | const PROMISE = Symbol('$$promise') | ||||||
|  |  | ||||||
|  | export default class Fetcher { | ||||||
|  |   get [Symbol.toStringTag]() { | ||||||
|  |     return '[object Fetcher]' | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   constructor() { | ||||||
|  |     this[PROMISE] = new Promise((resolve, reject) => { | ||||||
|  |       this.resolve = resolve | ||||||
|  |       this.reject = reject | ||||||
|  |     }) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async source() { | ||||||
|  |     return this[PROMISE] | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async abort() { | ||||||
|  |     ;(await this.source())?.abort() | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								uni_modules/u-ajax/js_sdk/lib/adapters/http.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,16 @@ | |||||||
|  | export default function adapter(config) { | ||||||
|  |   return new Promise((resolve, reject) => { | ||||||
|  |     const requestTask = uni.request({ | ||||||
|  |       ...config, | ||||||
|  |       complete: result => { | ||||||
|  |         // 根据状态码判断要执行的触发的状态 | ||||||
|  |         const response = { config, ...result } | ||||||
|  |         !config.validateStatus || config.validateStatus(result.statusCode) | ||||||
|  |           ? resolve(response) | ||||||
|  |           : reject(response) | ||||||
|  |       } | ||||||
|  |     }) | ||||||
|  |  | ||||||
|  |     config.fetcher?.resolve(requestTask) | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										72
									
								
								uni_modules/u-ajax/js_sdk/lib/core/Ajax.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,72 @@ | |||||||
|  | import InterceptorManager from './InterceptorManager' | ||||||
|  | import buildURL from '../helpers/buildURL' | ||||||
|  | import mergeConfig from '../helpers/mergeConfig' | ||||||
|  | import dispatchRequest from './dispatchRequest' | ||||||
|  | import { detachCancel, dispatchCancel, interceptCancel } from './handleCancel' | ||||||
|  | import defaults, { METHOD } from '../defaults' | ||||||
|  | import { forEach, merge } from '../utils' | ||||||
|  |  | ||||||
|  | export default function Ajax(defaultConfig) { | ||||||
|  |   // 挂载当前实例配置 | ||||||
|  |   ajax.config = Object.freeze( | ||||||
|  |     typeof defaultConfig === 'object' ? merge(defaultConfig) : defaultConfig | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  |   // 挂载全局默认配置引用 | ||||||
|  |   ajax.defaults = defaults | ||||||
|  |  | ||||||
|  |   // 挂载拦截器 | ||||||
|  |   ajax.interceptors = { | ||||||
|  |     request: new InterceptorManager(), | ||||||
|  |     response: new InterceptorManager() | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // 挂载获取实例请求地址方法 | ||||||
|  |   ajax.getURL = async function getURL(config) { | ||||||
|  |     const combineConfig = await mergeConfig(defaults, defaultConfig, config) | ||||||
|  |     return buildURL(combineConfig).replace(/^\?/, '') | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // 挂载对应的 method 方法 | ||||||
|  |   forEach(METHOD, method => { | ||||||
|  |     ajax[method] = function methodAjax(url, data, config) { | ||||||
|  |       if (typeof url === 'string') return ajax(url, data, { ...config, method }) | ||||||
|  |       return ajax({ ...url, method }) | ||||||
|  |     } | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   function ajax(url, data, config) { | ||||||
|  |     const newConfig = typeof url === 'string' ? { ...config, url, data } : { ...url } | ||||||
|  |  | ||||||
|  |     // 声明 Promise 链 | ||||||
|  |     const chain = [dispatchRequest, dispatchCancel] | ||||||
|  |  | ||||||
|  |     // 将请求拦截遍历添加到链前面 | ||||||
|  |     ajax.interceptors.request.forEach( | ||||||
|  |       ({ fulfilled, rejected }) => chain.unshift(fulfilled, rejected), | ||||||
|  |       true | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     // 将响应拦截遍历添加到链后面 | ||||||
|  |     ajax.interceptors.response.forEach( | ||||||
|  |       ({ fulfilled, rejected }) => chain.push(fulfilled, interceptCancel(rejected)), | ||||||
|  |       false | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     // 先执行获取 config 请求配置 | ||||||
|  |     chain.unshift(config => mergeConfig(defaults, defaultConfig, config), undefined) | ||||||
|  |  | ||||||
|  |     // 处理发起请求前的错误数据 | ||||||
|  |     chain.push(undefined, detachCancel) | ||||||
|  |  | ||||||
|  |     // 创建请求Promise,后面遍历链将链上方法传递到then回调 | ||||||
|  |     let request = Promise.resolve(newConfig) | ||||||
|  |     while (chain.length) { | ||||||
|  |       request = request.then(chain.shift(), chain.shift()) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return request | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return ajax | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								uni_modules/u-ajax/js_sdk/lib/core/InterceptorManager.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,32 @@ | |||||||
|  | /** | ||||||
|  |  * 拦截器类 | ||||||
|  |  */ | ||||||
|  | export default class InterceptorManager { | ||||||
|  |   handlers = [] | ||||||
|  |  | ||||||
|  |   use(fulfilled, rejected) { | ||||||
|  |     this.handlers.push({ | ||||||
|  |       fulfilled, | ||||||
|  |       rejected | ||||||
|  |     }) | ||||||
|  |     return this.handlers.length - 1 | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   eject(id) { | ||||||
|  |     if (this.handlers[id]) { | ||||||
|  |       this.handlers[id] = null | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   forEach(fn, reverse = false) { | ||||||
|  |     if (reverse) { | ||||||
|  |       for (let i = this.handlers.length - 1; i >= 0; i--) { | ||||||
|  |         this.handlers[i] !== null && fn(this.handlers[i]) | ||||||
|  |       } | ||||||
|  |     } else { | ||||||
|  |       for (let i = 0, l = this.handlers.length; i < l; i++) { | ||||||
|  |         this.handlers[i] !== null && fn(this.handlers[i]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								uni_modules/u-ajax/js_sdk/lib/core/dispatchRequest.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | |||||||
|  | import buildURL from '../helpers/buildURL' | ||||||
|  | import isCallback from '../helpers/isCallback' | ||||||
|  | import { forEach, isPlainObject, merge } from '../utils' | ||||||
|  | import { HEADER } from '../defaults' | ||||||
|  |  | ||||||
|  | /** 派发请求方法 */ | ||||||
|  | export default function dispatchRequest(config) { | ||||||
|  |   // 拼接 url | ||||||
|  |   config.url = buildURL(config) | ||||||
|  |  | ||||||
|  |   // 请求方法转大写 | ||||||
|  |   config.method = (config.method || 'get').toUpperCase() | ||||||
|  |  | ||||||
|  |   // 调整 header 优先级 | ||||||
|  |   config.header = merge( | ||||||
|  |     config.header.common, | ||||||
|  |     config.header[config.method.toLowerCase()], | ||||||
|  |     config.header | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  |   // 清除多余的请求头 | ||||||
|  |   forEach(HEADER, h => isPlainObject(config.header[h]) && delete config.header[h]) | ||||||
|  |  | ||||||
|  |   // 清除回调函数 | ||||||
|  |   forEach(config, (val, key) => isCallback(key) && delete config[key]) | ||||||
|  |  | ||||||
|  |   // 执行请求方法 | ||||||
|  |   return config.adapter(config) | ||||||
|  | } | ||||||
							
								
								
									
										35
									
								
								uni_modules/u-ajax/js_sdk/lib/core/handleCancel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,35 @@ | |||||||
|  | const CANCEL = Symbol('$$cancel') | ||||||
|  |  | ||||||
|  | function hasCancel(target) { | ||||||
|  |   return target === null || target === undefined | ||||||
|  |     ? false | ||||||
|  |     : Object.prototype.hasOwnProperty.call(target, CANCEL) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 派发请求拒绝方法,处理发起请求前错误,取消执行请求,并防止进入响应拦截器 | ||||||
|  |  * @param {*} reason 错误原因 | ||||||
|  |  * @returns {Promise} 封装了 CANCEL 的失败对象 | ||||||
|  |  */ | ||||||
|  | export function dispatchCancel(reason) { | ||||||
|  |   return Promise.reject({ [CANCEL]: reason }) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 拦截失败对象 | ||||||
|  |  * @param {Function} rejected 响应错误拦截器 | ||||||
|  |  */ | ||||||
|  | export function interceptCancel(rejected) { | ||||||
|  |   // 判断发起请求前是否发生错误,如果发生错误则不执行后面的响应错误拦截器 | ||||||
|  |   return ( | ||||||
|  |     rejected && (response => (hasCancel(response) ? Promise.reject(response) : rejected(response))) | ||||||
|  |   ) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 分离失败对象 | ||||||
|  |  * @param {*} response 封装了 CANCEL 的失败对象 | ||||||
|  |  */ | ||||||
|  | export function detachCancel(error) { | ||||||
|  |   return Promise.reject(hasCancel(error) ? error[CANCEL] : error) | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								uni_modules/u-ajax/js_sdk/lib/defaults.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,16 @@ | |||||||
|  | import adapter from './adapters/http' | ||||||
|  | import { forEach } from './utils' | ||||||
|  |  | ||||||
|  | export const METHOD = ['get', 'post', 'put', 'delete', 'connect', 'head', 'options', 'trace'] | ||||||
|  | export const HEADER = ['common', ...METHOD] | ||||||
|  |  | ||||||
|  | const defaults = { | ||||||
|  |   adapter, | ||||||
|  |   header: {}, | ||||||
|  |   method: 'GET', | ||||||
|  |   validateStatus: statusCode => statusCode >= 200 && statusCode < 300 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | forEach(HEADER, h => (defaults.header[h] = {})) | ||||||
|  |  | ||||||
|  | export default defaults | ||||||
							
								
								
									
										83
									
								
								uni_modules/u-ajax/js_sdk/lib/helpers/buildURL.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,83 @@ | |||||||
|  | import { forEach, isArray } from '../utils' | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 根据 baseURL 和 url 拼接 | ||||||
|  |  * @param {string} baseURL 请求根地址 | ||||||
|  |  * @param {string} relativeURL 请求参数地址 | ||||||
|  |  * @returns {string} 拼接后的地址 | ||||||
|  |  */ | ||||||
|  | function combineURL(baseURL = '', relativeURL = '') { | ||||||
|  |   // 判断是否 http:// 或 https:// 开头 | ||||||
|  |   if (/^https?:\/\//.test(relativeURL)) return relativeURL | ||||||
|  |   // 去除 baseURL 结尾斜杠,去除 relativeURL 开头斜杠,再判断拼接 | ||||||
|  |   return relativeURL ? baseURL.replace(/\/+$/, '') + '/' + relativeURL.replace(/^\/+/, '') : baseURL | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function encode(val) { | ||||||
|  |   return encodeURIComponent(val) | ||||||
|  |     .replace(/%3A/gi, ':') | ||||||
|  |     .replace(/%24/g, '$') | ||||||
|  |     .replace(/%2C/gi, ',') | ||||||
|  |     .replace(/%20/g, '+') | ||||||
|  |     .replace(/%5B/gi, '[') | ||||||
|  |     .replace(/%5D/gi, ']') | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function querystring(url, params) { | ||||||
|  |   let query | ||||||
|  |  | ||||||
|  |   const parts = [] | ||||||
|  |   forEach(params, (val, key) => { | ||||||
|  |     if (val === null || typeof val === 'undefined') return | ||||||
|  |  | ||||||
|  |     if (isArray(val)) key = key + '[]' | ||||||
|  |     else val = [val] | ||||||
|  |  | ||||||
|  |     forEach(val, v => { | ||||||
|  |       if (v !== null && typeof v === 'object') { | ||||||
|  |         v = JSON.stringify(v) | ||||||
|  |       } | ||||||
|  |       parts.push(encode(key) + '=' + encode(v)) | ||||||
|  |     }) | ||||||
|  |   }) | ||||||
|  |   query = parts.join('&') | ||||||
|  |  | ||||||
|  |   if (query) { | ||||||
|  |     const hashmarkIndex = url.indexOf('#') | ||||||
|  |     hashmarkIndex !== -1 && (url = url.slice(0, hashmarkIndex)) | ||||||
|  |     url += (url.indexOf('?') === -1 ? '?' : '&') + query | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return url | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 根据 baseURL、url、params query 编译请求URL | ||||||
|  |  * @returns {string} 处理后的地址 | ||||||
|  |  */ | ||||||
|  | export default function buildURL({ baseURL, url: relativeURL, params, query } = {}) { | ||||||
|  |   let url = combineURL(baseURL, relativeURL) | ||||||
|  |  | ||||||
|  |   if (!params && !query) { | ||||||
|  |     return url | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (params) { | ||||||
|  |     if (/\/:/.test(url)) { | ||||||
|  |       // 是否是 params 参数地址,并对应设置 | ||||||
|  |       forEach(params, (val, key) => { | ||||||
|  |         url = url.replace(`/:${key}`, `/${encode(String(val))}`) | ||||||
|  |       }) | ||||||
|  |     } else if (!query) { | ||||||
|  |       // 兼容旧的 params 属性设置 query | ||||||
|  |       url = querystring(url, params) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // 设置 query 参数 | ||||||
|  |   if (query) { | ||||||
|  |     url = querystring(url, query) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return url | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								uni_modules/u-ajax/js_sdk/lib/helpers/isCallback.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,8 @@ | |||||||
|  | /** | ||||||
|  |  * 判断参数是否含有回调参数 success / fail / complete 之一 | ||||||
|  |  * @param {string} field 参数的 Key 值字符串 | ||||||
|  |  * @returns {boolean} 返回判断值 | ||||||
|  |  */ | ||||||
|  | export default function isCallback(field) { | ||||||
|  |   return ['success', 'fail', 'complete'].includes(field) | ||||||
|  | } | ||||||
							
								
								
									
										41
									
								
								uni_modules/u-ajax/js_sdk/lib/helpers/mergeConfig.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,41 @@ | |||||||
|  | import { assign, forEach } from '../utils' | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 深度合并,且不合并 undefined 值 | ||||||
|  |  * @param {object} obj1 前对象 | ||||||
|  |  * @param {object} obj2 后对象 | ||||||
|  |  * @returns {object} 合并后的对象 | ||||||
|  |  */ | ||||||
|  | function merge(obj1 = {}, obj2 = {}) { | ||||||
|  |   const obj = {} | ||||||
|  |  | ||||||
|  |   const objKeys = Object.keys({ ...obj1, ...obj2 }) | ||||||
|  |  | ||||||
|  |   forEach(objKeys, prop => { | ||||||
|  |     if (obj2[prop] !== undefined) { | ||||||
|  |       obj[prop] = assign(obj1[prop], obj2[prop]) | ||||||
|  |     } else if (obj1[prop] !== undefined) { | ||||||
|  |       obj[prop] = assign(undefined, obj1[prop]) | ||||||
|  |     } | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   return obj | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 合并请求配置 | ||||||
|  |  * @param  {...object|function} args 请求配置 | ||||||
|  |  * @returns {object} 合并后的请求配置 | ||||||
|  |  */ | ||||||
|  | export default async function mergeConfig(...args) { | ||||||
|  |   let config = {} | ||||||
|  |  | ||||||
|  |   for (let i = 0, l = args.length; i < l; i++) { | ||||||
|  |     const current = typeof args[i] === 'function' ? await args[i]() : args[i] | ||||||
|  |     config = merge(config, current) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   config.method = config.method.toUpperCase() | ||||||
|  |  | ||||||
|  |   return config | ||||||
|  | } | ||||||
							
								
								
									
										77
									
								
								uni_modules/u-ajax/js_sdk/lib/utils.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,77 @@ | |||||||
|  | /** | ||||||
|  |  * 获取值的原始类型字符串,例如 [object Object] | ||||||
|  |  */ | ||||||
|  | const _toString = Object.prototype.toString | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 判断是否为数组 | ||||||
|  |  * @param {*} val 要判断的值 | ||||||
|  |  * @returns {boolean} 返回判断结果 | ||||||
|  |  */ | ||||||
|  | export function isArray(val) { | ||||||
|  |   return _toString.call(val) === '[object Array]' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 判断是否为普通对象 | ||||||
|  |  * @param {*} val 要判断的值 | ||||||
|  |  * @returns {boolean} 返回判断结果 | ||||||
|  |  */ | ||||||
|  | export function isPlainObject(val) { | ||||||
|  |   return _toString.call(val) === '[object Object]' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 遍历 | ||||||
|  |  * @param {object|array} obj 要迭代的对象 | ||||||
|  |  * @param {function} fn 为每个项调用的回调 | ||||||
|  |  */ | ||||||
|  | export function forEach(obj, fn) { | ||||||
|  |   if (obj === null || obj === undefined) return | ||||||
|  |   if (typeof obj !== 'object') obj = [obj] | ||||||
|  |   if (isArray(obj)) { | ||||||
|  |     for (let i = 0, l = obj.length; i < l; i++) { | ||||||
|  |       fn.call(null, obj[i], i, obj) | ||||||
|  |     } | ||||||
|  |   } else { | ||||||
|  |     for (const k in obj) { | ||||||
|  |       if (Object.prototype.hasOwnProperty.call(obj, k)) { | ||||||
|  |         fn.call(null, obj[k], k, obj) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 对象深合并 | ||||||
|  |  * @param  {...object} args 对象 | ||||||
|  |  * @returns {object} 合并后的对象 | ||||||
|  |  */ | ||||||
|  | export function merge(...args) { | ||||||
|  |   const result = {} | ||||||
|  |   for (let i = 0, l = args.length; i < l; i++) { | ||||||
|  |     if (isPlainObject(args[i])) { | ||||||
|  |       forEach(args[i], (val, key) => { | ||||||
|  |         result[key] = assign(result[key], val) | ||||||
|  |       }) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return result | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 合并分配到目标对象 | ||||||
|  |  * @param {*} target 目标对象 | ||||||
|  |  * @param {*} source 源对象 | ||||||
|  |  * @returns {*} 目标对象 | ||||||
|  |  */ | ||||||
|  | export function assign(target, source) { | ||||||
|  |   if (isPlainObject(target) && isPlainObject(source)) { | ||||||
|  |     return merge(target, source) | ||||||
|  |   } else if (isPlainObject(source)) { | ||||||
|  |     return merge({}, source) | ||||||
|  |   } else if (isArray(source)) { | ||||||
|  |     return source.slice() | ||||||
|  |   } | ||||||
|  |   return source | ||||||
|  | } | ||||||
							
								
								
									
										71
									
								
								uni_modules/u-ajax/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,71 @@ | |||||||
|  | { | ||||||
|  |   "id": "u-ajax", | ||||||
|  |   "displayName": "ajax request 请求", | ||||||
|  |   "version": "2.5.1", | ||||||
|  |   "description": "封装 uni.request,支持拦截器、接口根地址、默认配置、中断请求等功能", | ||||||
|  |   "keywords": [ | ||||||
|  |     "ajax", | ||||||
|  |     "http", | ||||||
|  |     "promise", | ||||||
|  |     "request", | ||||||
|  |     "task" | ||||||
|  | ], | ||||||
|  |   "main": "./js_sdk/index.js", | ||||||
|  |   "types": "./js_sdk/index.d.ts", | ||||||
|  |   "repository": "https://github.com/ponjs/uni-ajax", | ||||||
|  |   "dcloudext": { | ||||||
|  |     "type": "sdk-js", | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "插件不采集任何数据", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/uni-ajax" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y", | ||||||
|  |           "钉钉": "y", | ||||||
|  |           "快手": "y", | ||||||
|  |           "飞书": "y", | ||||||
|  |           "京东": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "y", | ||||||
|  |           "联盟": "y" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |           "vue2": "y", | ||||||
|  |           "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										31
									
								
								uni_modules/uni-badge/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,31 @@ | |||||||
|  | ## 1.2.1(2022-09-05) | ||||||
|  | - 修复 当 text 超过 max-num 时,badge 的宽度计算是根据 text 的长度计算,更改为 css 计算实际展示宽度,详见:[https://ask.dcloud.net.cn/question/150473](https://ask.dcloud.net.cn/question/150473) | ||||||
|  | ## 1.2.0(2021-11-19) | ||||||
|  | - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||||
|  | - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-badge](https://uniapp.dcloud.io/component/uniui/uni-badge) | ||||||
|  | ## 1.1.7(2021-11-08) | ||||||
|  | - 优化 升级ui | ||||||
|  | - 修改 size 属性默认值调整为 small | ||||||
|  | - 修改 type 属性,默认值调整为 error,info 替换 default | ||||||
|  | ## 1.1.6(2021-09-22) | ||||||
|  | - 修复 在字节小程序上样式不生效的 bug | ||||||
|  | ## 1.1.5(2021-07-30) | ||||||
|  | - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||||
|  | ## 1.1.4(2021-07-29) | ||||||
|  | - 修复 去掉 nvue 不支持css 的 align-self 属性,nvue 下不暂支持 absolute 属性 | ||||||
|  | ## 1.1.3(2021-06-24) | ||||||
|  | - 优化 示例项目 | ||||||
|  | ## 1.1.1(2021-05-12) | ||||||
|  | - 新增 组件示例地址 | ||||||
|  | ## 1.1.0(2021-05-12) | ||||||
|  | - 新增 uni-badge 的 absolute 属性,支持定位 | ||||||
|  | - 新增 uni-badge 的 offset 属性,支持定位偏移 | ||||||
|  | - 新增 uni-badge 的 is-dot 属性,支持仅显示有一个小点 | ||||||
|  | - 新增 uni-badge 的 max-num 属性,支持自定义封顶的数字值,超过 99 显示99+ | ||||||
|  | - 优化 uni-badge 属性 custom-style, 支持以对象形式自定义样式 | ||||||
|  | ## 1.0.7(2021-05-07) | ||||||
|  | - 修复 uni-badge 在 App 端,数字小于10时不是圆形的bug | ||||||
|  | - 修复 uni-badge 在父元素不是 flex 布局时,宽度缩小的bug | ||||||
|  | - 新增 uni-badge 属性 custom-style, 支持自定义样式 | ||||||
|  | ## 1.0.6(2021-02-04) | ||||||
|  | - 调整为uni_modules目录规范 | ||||||
							
								
								
									
										268
									
								
								uni_modules/uni-badge/components/uni-badge/uni-badge.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,268 @@ | |||||||
|  | <template> | ||||||
|  | 	<view class="uni-badge--x"> | ||||||
|  | 		<slot /> | ||||||
|  | 		<text v-if="text" :class="classNames" :style="[positionStyle, customStyle, dotStyle]" | ||||||
|  | 			class="uni-badge" @click="onClick()">{{displayValue}}</text> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	/** | ||||||
|  | 	 * Badge 数字角标 | ||||||
|  | 	 * @description 数字角标一般和其它控件(列表、9宫格等)配合使用,用于进行数量提示,默认为实心灰色背景 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=21 | ||||||
|  | 	 * @property {String} text 角标内容 | ||||||
|  | 	 * @property {String} size = [normal|small] 角标内容 | ||||||
|  | 	 * @property {String} type = [info|primary|success|warning|error] 颜色类型 | ||||||
|  | 	 * 	@value info 灰色 | ||||||
|  | 	 * 	@value primary 蓝色 | ||||||
|  | 	 * 	@value success 绿色 | ||||||
|  | 	 * 	@value warning 黄色 | ||||||
|  | 	 * 	@value error 红色 | ||||||
|  | 	 * @property {String} inverted = [true|false] 是否无需背景颜色 | ||||||
|  | 	 * @property {Number} maxNum 展示封顶的数字值,超过 99 显示 99+ | ||||||
|  | 	 * @property {String} absolute = [rightTop|rightBottom|leftBottom|leftTop] 开启绝对定位, 角标将定位到其包裹的标签的四角上		 | ||||||
|  | 	 * 	@value rightTop 右上 | ||||||
|  | 	 * 	@value rightBottom 右下 | ||||||
|  | 	 * 	@value leftTop 左上 | ||||||
|  | 	 * 	@value leftBottom 左下 | ||||||
|  | 	 * @property {Array[number]} offset	距定位角中心点的偏移量,只有存在 absolute 属性时有效,例如:[-10, -10] 表示向外偏移 10px,[10, 10] 表示向 absolute 指定的内偏移 10px | ||||||
|  | 	 * @property {String} isDot = [true|false] 是否显示为一个小点 | ||||||
|  | 	 * @event {Function} click 点击 Badge 触发事件 | ||||||
|  | 	 * @example <uni-badge text="1"></uni-badge> | ||||||
|  | 	 */ | ||||||
|  |  | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniBadge', | ||||||
|  | 		emits: ['click'], | ||||||
|  | 		props: { | ||||||
|  | 			type: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: 'error' | ||||||
|  | 			}, | ||||||
|  | 			inverted: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			isDot: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			maxNum: { | ||||||
|  | 				type: Number, | ||||||
|  | 				default: 99 | ||||||
|  | 			}, | ||||||
|  | 			absolute: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			offset: { | ||||||
|  | 				type: Array, | ||||||
|  | 				default () { | ||||||
|  | 					return [0, 0] | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			text: { | ||||||
|  | 				type: [String, Number], | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			size: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: 'small' | ||||||
|  | 			}, | ||||||
|  | 			customStyle: { | ||||||
|  | 				type: Object, | ||||||
|  | 				default () { | ||||||
|  | 					return {} | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			return {}; | ||||||
|  | 		}, | ||||||
|  | 		computed: { | ||||||
|  | 			width() { | ||||||
|  | 				return String(this.text).length * 8 + 12 | ||||||
|  | 			}, | ||||||
|  | 			classNames() { | ||||||
|  | 				const { | ||||||
|  | 					inverted, | ||||||
|  | 					type, | ||||||
|  | 					size, | ||||||
|  | 					absolute | ||||||
|  | 				} = this | ||||||
|  | 				return [ | ||||||
|  | 					inverted ? 'uni-badge--' + type + '-inverted' : '', | ||||||
|  | 					'uni-badge--' + type, | ||||||
|  | 					'uni-badge--' + size, | ||||||
|  | 					absolute ? 'uni-badge--absolute' : '' | ||||||
|  | 				].join(' ') | ||||||
|  | 			}, | ||||||
|  | 			positionStyle() { | ||||||
|  | 				if (!this.absolute) return {} | ||||||
|  | 				let w = this.width / 2, | ||||||
|  | 					h = 10 | ||||||
|  | 				if (this.isDot) { | ||||||
|  | 					w = 5 | ||||||
|  | 					h = 5 | ||||||
|  | 				} | ||||||
|  | 				const x = `${- w  + this.offset[0]}px` | ||||||
|  | 				const y = `${- h + this.offset[1]}px` | ||||||
|  |  | ||||||
|  | 				const whiteList = { | ||||||
|  | 					rightTop: { | ||||||
|  | 						right: x, | ||||||
|  | 						top: y | ||||||
|  | 					}, | ||||||
|  | 					rightBottom: { | ||||||
|  | 						right: x, | ||||||
|  | 						bottom: y | ||||||
|  | 					}, | ||||||
|  | 					leftBottom: { | ||||||
|  | 						left: x, | ||||||
|  | 						bottom: y | ||||||
|  | 					}, | ||||||
|  | 					leftTop: { | ||||||
|  | 						left: x, | ||||||
|  | 						top: y | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 				const match = whiteList[this.absolute] | ||||||
|  | 				return match ? match : whiteList['rightTop'] | ||||||
|  | 			}, | ||||||
|  | 			dotStyle() { | ||||||
|  | 				if (!this.isDot) return {} | ||||||
|  | 				return { | ||||||
|  | 					width: '10px', | ||||||
|  | 					minWidth: '0', | ||||||
|  | 					height: '10px', | ||||||
|  | 					padding: '0', | ||||||
|  | 					borderRadius: '10px' | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			displayValue() { | ||||||
|  | 				const { | ||||||
|  | 					isDot, | ||||||
|  | 					text, | ||||||
|  | 					maxNum | ||||||
|  | 				} = this | ||||||
|  | 				return isDot ? '' : (Number(text) > maxNum ? `${maxNum}+` : text) | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			onClick() { | ||||||
|  | 				this.$emit('click'); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" > | ||||||
|  | 	$uni-primary: #2979ff !default; | ||||||
|  | 	$uni-success: #4cd964 !default; | ||||||
|  | 	$uni-warning: #f0ad4e !default; | ||||||
|  | 	$uni-error: #dd524d !default; | ||||||
|  | 	$uni-info: #909399 !default; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	$bage-size: 12px; | ||||||
|  | 	$bage-small: scale(0.8); | ||||||
|  |  | ||||||
|  | 	.uni-badge--x { | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		// align-self: flex-start; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: inline-block; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		position: relative; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-badge--absolute { | ||||||
|  | 		position: absolute; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-badge--small { | ||||||
|  | 		transform: $bage-small; | ||||||
|  | 		transform-origin: center center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-badge { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		box-sizing: border-box; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		justify-content: center; | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		height: 20px; | ||||||
|  | 		min-width: 20px; | ||||||
|  | 		padding: 0 4px; | ||||||
|  | 		line-height: 18px; | ||||||
|  | 		color: #fff; | ||||||
|  | 		border-radius: 100px; | ||||||
|  | 		background-color: $uni-info; | ||||||
|  | 		background-color: transparent; | ||||||
|  | 		border: 1px solid #fff; | ||||||
|  | 		text-align: center; | ||||||
|  | 		font-family: 'Helvetica Neue', Helvetica, sans-serif; | ||||||
|  | 		font-feature-settings: "tnum"; | ||||||
|  | 		font-size: $bage-size; | ||||||
|  | 		/* #ifdef H5 */ | ||||||
|  | 		z-index: 999; | ||||||
|  | 		cursor: pointer; | ||||||
|  | 		/* #endif */ | ||||||
|  |  | ||||||
|  | 		&--info { | ||||||
|  | 			color: #fff; | ||||||
|  | 			background-color: $uni-info; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--primary { | ||||||
|  | 			background-color: $uni-primary; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--success { | ||||||
|  | 			background-color: $uni-success; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--warning { | ||||||
|  | 			background-color: $uni-warning; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--error { | ||||||
|  | 			background-color: $uni-error; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--inverted { | ||||||
|  | 			padding: 0 5px 0 0; | ||||||
|  | 			color: $uni-info; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--info-inverted { | ||||||
|  | 			color: $uni-info; | ||||||
|  | 			background-color: transparent; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--primary-inverted { | ||||||
|  | 			color: $uni-primary; | ||||||
|  | 			background-color: transparent; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--success-inverted { | ||||||
|  | 			color: $uni-success; | ||||||
|  | 			background-color: transparent; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--warning-inverted { | ||||||
|  | 			color: $uni-warning; | ||||||
|  | 			background-color: transparent; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&--error-inverted { | ||||||
|  | 			color: $uni-error; | ||||||
|  | 			background-color: transparent; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										85
									
								
								uni_modules/uni-badge/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,85 @@ | |||||||
|  | { | ||||||
|  |   "id": "uni-badge", | ||||||
|  |   "displayName": "uni-badge 数字角标", | ||||||
|  |   "version": "1.2.1", | ||||||
|  |   "description": "数字角标(徽章)组件,在元素周围展示消息提醒,一般用于列表、九宫格、按钮等地方。", | ||||||
|  |   "keywords": [ | ||||||
|  |     "", | ||||||
|  |     "badge", | ||||||
|  |     "uni-ui", | ||||||
|  |     "uniui", | ||||||
|  |     "数字角标", | ||||||
|  |     "徽章" | ||||||
|  | ], | ||||||
|  |   "repository": "https://github.com/dcloudio/uni-ui", | ||||||
|  |   "engines": { | ||||||
|  |     "HBuilderX": "" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "example": "../../temps/example_temps" | ||||||
|  |   }, | ||||||
|  | "dcloudext": { | ||||||
|  |     "sale": { | ||||||
|  |       "regular": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       }, | ||||||
|  |       "sourcecode": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "contact": { | ||||||
|  |       "qq": "" | ||||||
|  |     }, | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "无", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui", | ||||||
|  |     "type": "component-vue" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "dependencies": ["uni-scss"], | ||||||
|  |     "encrypt": [], | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "y", | ||||||
|  |           "联盟": "y" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |             "vue2": "y", | ||||||
|  |             "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										10
									
								
								uni_modules/uni-badge/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,10 @@ | |||||||
|  | ## Badge 数字角标 | ||||||
|  | > **组件名:uni-badge** | ||||||
|  | > 代码块: `uBadge` | ||||||
|  |  | ||||||
|  | 数字角标一般和其它控件(列表、9宫格等)配合使用,用于进行数量提示,默认为实心灰色背景, | ||||||
|  |  | ||||||
|  | ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-badge) | ||||||
|  | #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										13
									
								
								uni_modules/uni-grid/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,13 @@ | |||||||
|  | ## 1.4.0(2021-11-19) | ||||||
|  | - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||||
|  | - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-grid](https://uniapp.dcloud.io/component/uniui/uni-grid) | ||||||
|  | ## 1.3.2(2021-11-09)  | ||||||
|  | - 新增 提供组件设计资源,组件样式调整 | ||||||
|  | ## 1.3.1(2021-07-30) | ||||||
|  | - 优化 vue3下事件警告的问题 | ||||||
|  | ## 1.3.0(2021-07-13) | ||||||
|  | - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||||
|  | ## 1.2.4(2021-05-12) | ||||||
|  | - 新增 组件示例地址 | ||||||
|  | ## 1.2.3(2021-02-05) | ||||||
|  | - 调整为uni_modules目录规范 | ||||||
							
								
								
									
										127
									
								
								uni_modules/uni-grid/components/uni-grid-item/uni-grid-item.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,127 @@ | |||||||
|  | <template> | ||||||
|  | 	<view v-if="width" :style="'width:'+width+';'+(square?'height:'+width:'')" class="uni-grid-item"> | ||||||
|  | 		<view :class="{ 'uni-grid-item--border': showBorder,  'uni-grid-item--border-top': showBorder && index < column, 'uni-highlight': highlight }" | ||||||
|  | 		 :style="{'border-right-color': borderColor ,'border-bottom-color': borderColor ,'border-top-color': borderColor }" | ||||||
|  | 		 class="uni-grid-item__box" @click="_onClick"> | ||||||
|  | 			<slot /> | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	/** | ||||||
|  | 	 * GridItem 宫格 | ||||||
|  | 	 * @description 宫格组件 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=27 | ||||||
|  | 	 * @property {Number} index 子组件的唯一标识 ,点击gird会返回当前的标识 | ||||||
|  | 	 */ | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniGridItem', | ||||||
|  | 		inject: ['grid'], | ||||||
|  | 		props: { | ||||||
|  | 			index: { | ||||||
|  | 				type: Number, | ||||||
|  | 				default: 0 | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				column: 0, | ||||||
|  | 				showBorder: true, | ||||||
|  | 				square: true, | ||||||
|  | 				highlight: true, | ||||||
|  | 				left: 0, | ||||||
|  | 				top: 0, | ||||||
|  | 				openNum: 2, | ||||||
|  | 				width: 0, | ||||||
|  | 				borderColor: '#e5e5e5' | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		created() { | ||||||
|  | 			this.column = this.grid.column | ||||||
|  | 			this.showBorder = this.grid.showBorder | ||||||
|  | 			this.square = this.grid.square | ||||||
|  | 			this.highlight = this.grid.highlight | ||||||
|  | 			this.top = this.hor === 0 ? this.grid.hor : this.hor | ||||||
|  | 			this.left = this.ver === 0 ? this.grid.ver : this.ver | ||||||
|  | 			this.borderColor = this.grid.borderColor | ||||||
|  | 			this.grid.children.push(this) | ||||||
|  | 			// this.grid.init() | ||||||
|  | 			this.width = this.grid.width | ||||||
|  | 		}, | ||||||
|  | 		beforeDestroy() { | ||||||
|  | 			this.grid.children.forEach((item, index) => { | ||||||
|  | 				if (item === this) { | ||||||
|  | 					this.grid.children.splice(index, 1) | ||||||
|  | 				} | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			_onClick() { | ||||||
|  | 				this.grid.change({ | ||||||
|  | 					detail: { | ||||||
|  | 						index: this.index | ||||||
|  | 					} | ||||||
|  | 				}) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | 	.uni-grid-item { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		height: 100%; | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifdef H5 */ | ||||||
|  | 		cursor: pointer; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-grid-item__box { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		width: 100%; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		position: relative; | ||||||
|  | 		flex: 1; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		// justify-content: center; | ||||||
|  | 		// align-items: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-grid-item--border { | ||||||
|  | 		position: relative; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		border-bottom-color: #D2D2D2; | ||||||
|  | 		border-bottom-style: solid; | ||||||
|  | 		border-bottom-width: 0.5px; | ||||||
|  | 		border-right-color: #D2D2D2; | ||||||
|  | 		border-right-style: solid; | ||||||
|  | 		border-right-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		z-index: 0; | ||||||
|  | 		border-bottom: 1px #D2D2D2 solid; | ||||||
|  | 		border-right: 1px #D2D2D2 solid; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  | 	.uni-grid-item--border-top { | ||||||
|  | 		position: relative; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		border-top-color: #D2D2D2; | ||||||
|  | 		border-top-style: solid; | ||||||
|  | 		border-top-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		border-top: 1px #D2D2D2 solid; | ||||||
|  | 		z-index: 0; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	.uni-highlight:active { | ||||||
|  | 		background-color: #f1f1f1; | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										142
									
								
								uni_modules/uni-grid/components/uni-grid/uni-grid.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,142 @@ | |||||||
|  | <template> | ||||||
|  | 	<view class="uni-grid-wrap"> | ||||||
|  | 		<view :id="elId" ref="uni-grid" class="uni-grid" :class="{ 'uni-grid--border': showBorder }" :style="{ 'border-left-color':borderColor}"> | ||||||
|  | 			<slot /> | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	// #ifdef APP-NVUE | ||||||
|  | 	const dom = uni.requireNativePlugin('dom'); | ||||||
|  | 	// #endif | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Grid 宫格 | ||||||
|  | 	 * @description 宫格组件 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=27 | ||||||
|  | 	 * @property {Number} column 每列显示个数 | ||||||
|  | 	 * @property {String} borderColor 边框颜色 | ||||||
|  | 	 * @property {Boolean} showBorder 是否显示边框 | ||||||
|  | 	 * @property {Boolean} square 是否方形显示 | ||||||
|  | 	 * @property {Boolean} Boolean 点击背景是否高亮 | ||||||
|  | 	 * @event {Function} change 点击 grid 触发,e={detail:{index:0}},index 为当前点击 gird 下标 | ||||||
|  | 	 */ | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniGrid', | ||||||
|  | 		emits:['change'], | ||||||
|  | 		props: { | ||||||
|  | 			// 每列显示个数 | ||||||
|  | 			column: { | ||||||
|  | 				type: Number, | ||||||
|  | 				default: 3 | ||||||
|  | 			}, | ||||||
|  | 			// 是否显示边框 | ||||||
|  | 			showBorder: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: true | ||||||
|  | 			}, | ||||||
|  | 			// 边框颜色 | ||||||
|  | 			borderColor: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '#D2D2D2' | ||||||
|  | 			}, | ||||||
|  | 			// 是否正方形显示,默认为 true | ||||||
|  | 			square: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: true | ||||||
|  | 			}, | ||||||
|  | 			highlight: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: true | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		provide() { | ||||||
|  | 			return { | ||||||
|  | 				grid: this | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			const elId = `Uni_${Math.ceil(Math.random() * 10e5).toString(36)}` | ||||||
|  | 			return { | ||||||
|  | 				elId, | ||||||
|  | 				width: 0 | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		created() { | ||||||
|  | 			this.children = [] | ||||||
|  | 		}, | ||||||
|  | 		mounted() { | ||||||
|  | 			this.$nextTick(()=>{ | ||||||
|  | 				this.init() | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			init() { | ||||||
|  | 				setTimeout(() => { | ||||||
|  | 					this._getSize((width) => { | ||||||
|  | 						this.children.forEach((item, index) => { | ||||||
|  | 							item.width = width | ||||||
|  | 						}) | ||||||
|  | 					}) | ||||||
|  | 				}, 50) | ||||||
|  | 			}, | ||||||
|  | 			change(e) { | ||||||
|  | 				this.$emit('change', e) | ||||||
|  | 			}, | ||||||
|  | 			_getSize(fn) { | ||||||
|  | 				// #ifndef APP-NVUE | ||||||
|  | 				uni.createSelectorQuery() | ||||||
|  | 					.in(this) | ||||||
|  | 					.select(`#${this.elId}`) | ||||||
|  | 					.boundingClientRect() | ||||||
|  | 					.exec(ret => { | ||||||
|  | 						this.width = parseInt((ret[0].width - 1) / this.column) + 'px' | ||||||
|  | 						fn(this.width) | ||||||
|  | 					}) | ||||||
|  | 				// #endif | ||||||
|  | 				// #ifdef APP-NVUE | ||||||
|  | 				dom.getComponentRect(this.$refs['uni-grid'], (ret) => { | ||||||
|  | 					this.width = parseInt((ret.size.width - 1) / this.column) + 'px' | ||||||
|  | 					fn(this.width) | ||||||
|  | 				}) | ||||||
|  | 				// #endif | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | 	.uni-grid-wrap { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex: 1; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		/* #ifdef H5 */ | ||||||
|  | 		width: 100%; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-grid { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		// flex: 1; | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		flex-wrap: wrap; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-grid--border { | ||||||
|  | 		position: relative; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		border-left-color: #D2D2D2; | ||||||
|  | 		border-left-style: solid; | ||||||
|  | 		border-left-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		z-index: 1; | ||||||
|  | 		border-left: 1px #D2D2D2 solid; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										86
									
								
								uni_modules/uni-grid/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,86 @@ | |||||||
|  | { | ||||||
|  |   "id": "uni-grid", | ||||||
|  |   "displayName": "uni-grid 宫格", | ||||||
|  |   "version": "1.4.0", | ||||||
|  |   "description": "Grid 宫格组件,提供移动端常见的宫格布局,如九宫格。", | ||||||
|  |   "keywords": [ | ||||||
|  |     "uni-ui", | ||||||
|  |     "uniui", | ||||||
|  |     "九宫格", | ||||||
|  |     "表格" | ||||||
|  | ], | ||||||
|  |   "repository": "https://github.com/dcloudio/uni-ui", | ||||||
|  |   "engines": { | ||||||
|  |     "HBuilderX": "" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "example": "../../temps/example_temps" | ||||||
|  |   }, | ||||||
|  |   "dcloudext": { | ||||||
|  |     "category": [ | ||||||
|  |       "前端组件", | ||||||
|  |       "通用组件" | ||||||
|  |     ], | ||||||
|  |     "sale": { | ||||||
|  |       "regular": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       }, | ||||||
|  |       "sourcecode": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "contact": { | ||||||
|  |       "qq": "" | ||||||
|  |     }, | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "无", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "dependencies": ["uni-scss","uni-icons"], | ||||||
|  |     "encrypt": [], | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "u", | ||||||
|  |           "联盟": "u" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |             "vue2": "y", | ||||||
|  |             "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										11
									
								
								uni_modules/uni-grid/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,11 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  | ## Grid 宫格 | ||||||
|  | > **组件名:uni-grid** | ||||||
|  | > 代码块: `uGrid` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 宫格组件。 | ||||||
|  |  | ||||||
|  | ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-grid) | ||||||
|  | #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||||
							
								
								
									
										22
									
								
								uni_modules/uni-icons/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | |||||||
|  | ## 1.3.5(2022-01-24) | ||||||
|  | - 优化 size 属性可以传入不带单位的字符串数值 | ||||||
|  | ## 1.3.4(2022-01-24) | ||||||
|  | - 优化 size 支持其他单位 | ||||||
|  | ## 1.3.3(2022-01-17) | ||||||
|  | - 修复 nvue 有些图标不显示的bug,兼容老版本图标 | ||||||
|  | ## 1.3.2(2021-12-01) | ||||||
|  | - 优化 示例可复制图标名称 | ||||||
|  | ## 1.3.1(2021-11-23) | ||||||
|  | - 优化 兼容旧组件 type 值 | ||||||
|  | ## 1.3.0(2021-11-19) | ||||||
|  | - 新增 更多图标 | ||||||
|  | - 优化 自定义图标使用方式 | ||||||
|  | - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||||
|  | - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-icons](https://uniapp.dcloud.io/component/uniui/uni-icons) | ||||||
|  | ## 1.1.7(2021-11-08) | ||||||
|  | ## 1.2.0(2021-07-30) | ||||||
|  | - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||||
|  | ## 1.1.5(2021-05-12) | ||||||
|  | - 新增 组件示例地址 | ||||||
|  | ## 1.1.4(2021-02-05) | ||||||
|  | - 调整为uni_modules目录规范 | ||||||
							
								
								
									
										1169
									
								
								uni_modules/uni-icons/components/uni-icons/icons.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										96
									
								
								uni_modules/uni-icons/components/uni-icons/uni-icons.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,96 @@ | |||||||
|  | <template> | ||||||
|  | 	<!-- #ifdef APP-NVUE --> | ||||||
|  | 	<text :style="{ color: color, 'font-size': iconSize }" class="uni-icons" @click="_onClick">{{unicode}}</text> | ||||||
|  | 	<!-- #endif --> | ||||||
|  | 	<!-- #ifndef APP-NVUE --> | ||||||
|  | 	<text :style="{ color: color, 'font-size': iconSize }" class="uni-icons" :class="['uniui-'+type,customPrefix,customPrefix?type:'']" @click="_onClick"></text> | ||||||
|  | 	<!-- #endif --> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	import icons from './icons.js'; | ||||||
|  | 	const getVal = (val) => { | ||||||
|  | 		const reg = /^[0-9]*$/g | ||||||
|  | 		return (typeof val === 'number' || reg.test(val) )? val + 'px' : val; | ||||||
|  | 	}  | ||||||
|  | 	// #ifdef APP-NVUE | ||||||
|  | 	var domModule = weex.requireModule('dom'); | ||||||
|  | 	import iconUrl from './uniicons.ttf' | ||||||
|  | 	domModule.addRule('fontFace', { | ||||||
|  | 		'fontFamily': "uniicons", | ||||||
|  | 		'src': "url('"+iconUrl+"')" | ||||||
|  | 	}); | ||||||
|  | 	// #endif | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Icons 图标 | ||||||
|  | 	 * @description 用于展示 icons 图标 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=28 | ||||||
|  | 	 * @property {Number} size 图标大小 | ||||||
|  | 	 * @property {String} type 图标图案,参考示例 | ||||||
|  | 	 * @property {String} color 图标颜色 | ||||||
|  | 	 * @property {String} customPrefix 自定义图标 | ||||||
|  | 	 * @event {Function} click 点击 Icon 触发事件 | ||||||
|  | 	 */ | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniIcons', | ||||||
|  | 		emits:['click'], | ||||||
|  | 		props: { | ||||||
|  | 			type: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			color: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '#333333' | ||||||
|  | 			}, | ||||||
|  | 			size: { | ||||||
|  | 				type: [Number, String], | ||||||
|  | 				default: 16 | ||||||
|  | 			}, | ||||||
|  | 			customPrefix:{ | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				icons: icons.glyphs | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		computed:{ | ||||||
|  | 			unicode(){ | ||||||
|  | 				let code = this.icons.find(v=>v.font_class === this.type) | ||||||
|  | 				if(code){ | ||||||
|  | 					return unescape(`%u${code.unicode}`) | ||||||
|  | 				} | ||||||
|  | 				return '' | ||||||
|  | 			}, | ||||||
|  | 			iconSize(){ | ||||||
|  | 				return getVal(this.size) | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			_onClick() { | ||||||
|  | 				this.$emit('click') | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss"> | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	@import './uniicons.css'; | ||||||
|  | 	@font-face { | ||||||
|  | 		font-family: uniicons; | ||||||
|  | 		src: url('./uniicons.ttf') format('truetype'); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  | 	.uni-icons { | ||||||
|  | 		font-family: uniicons; | ||||||
|  | 		text-decoration: none; | ||||||
|  | 		text-align: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | </style> | ||||||
							
								
								
									
										663
									
								
								uni_modules/uni-icons/components/uni-icons/uniicons.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,663 @@ | |||||||
|  | .uniui-color:before { | ||||||
|  |   content: "\e6cf"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-wallet:before { | ||||||
|  |   content: "\e6b1"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-settings-filled:before { | ||||||
|  |   content: "\e6ce"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-auth-filled:before { | ||||||
|  |   content: "\e6cc"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-shop-filled:before { | ||||||
|  |   content: "\e6cd"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-staff-filled:before { | ||||||
|  |   content: "\e6cb"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-vip-filled:before { | ||||||
|  |   content: "\e6c6"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-plus-filled:before { | ||||||
|  |   content: "\e6c7"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-folder-add-filled:before { | ||||||
|  |   content: "\e6c8"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-color-filled:before { | ||||||
|  |   content: "\e6c9"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-tune-filled:before { | ||||||
|  |   content: "\e6ca"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-calendar-filled:before { | ||||||
|  |   content: "\e6c0"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-notification-filled:before { | ||||||
|  |   content: "\e6c1"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-wallet-filled:before { | ||||||
|  |   content: "\e6c2"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-medal-filled:before { | ||||||
|  |   content: "\e6c3"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-gift-filled:before { | ||||||
|  |   content: "\e6c4"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-fire-filled:before { | ||||||
|  |   content: "\e6c5"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-refreshempty:before { | ||||||
|  |   content: "\e6bf"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-location-filled:before { | ||||||
|  |   content: "\e6af"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-person-filled:before { | ||||||
|  |   content: "\e69d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-personadd-filled:before { | ||||||
|  |   content: "\e698"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-back:before { | ||||||
|  |   content: "\e6b9"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-forward:before { | ||||||
|  |   content: "\e6ba"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrow-right:before { | ||||||
|  |   content: "\e6bb"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowthinright:before { | ||||||
|  |   content: "\e6bb"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrow-left:before { | ||||||
|  |   content: "\e6bc"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowthinleft:before { | ||||||
|  |   content: "\e6bc"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrow-up:before { | ||||||
|  |   content: "\e6bd"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowthinup:before { | ||||||
|  |   content: "\e6bd"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrow-down:before { | ||||||
|  |   content: "\e6be"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowthindown:before { | ||||||
|  |   content: "\e6be"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-bottom:before { | ||||||
|  |   content: "\e6b8"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowdown:before { | ||||||
|  |   content: "\e6b8"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-right:before { | ||||||
|  |   content: "\e6b5"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowright:before { | ||||||
|  |   content: "\e6b5"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-top:before { | ||||||
|  |   content: "\e6b6"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowup:before { | ||||||
|  |   content: "\e6b6"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-left:before { | ||||||
|  |   content: "\e6b7"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-arrowleft:before { | ||||||
|  |   content: "\e6b7"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-eye:before { | ||||||
|  |   content: "\e651"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-eye-filled:before { | ||||||
|  |   content: "\e66a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-eye-slash:before { | ||||||
|  |   content: "\e6b3"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-eye-slash-filled:before { | ||||||
|  |   content: "\e6b4"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-info-filled:before { | ||||||
|  |   content: "\e649"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-reload:before { | ||||||
|  |   content: "\e6b2"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-micoff-filled:before { | ||||||
|  |   content: "\e6b0"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-map-pin-ellipse:before { | ||||||
|  |   content: "\e6ac"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-map-pin:before { | ||||||
|  |   content: "\e6ad"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-location:before { | ||||||
|  |   content: "\e6ae"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-starhalf:before { | ||||||
|  |   content: "\e683"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-star:before { | ||||||
|  |   content: "\e688"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-star-filled:before { | ||||||
|  |   content: "\e68f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-calendar:before { | ||||||
|  |   content: "\e6a0"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-fire:before { | ||||||
|  |   content: "\e6a1"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-medal:before { | ||||||
|  |   content: "\e6a2"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-font:before { | ||||||
|  |   content: "\e6a3"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-gift:before { | ||||||
|  |   content: "\e6a4"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-link:before { | ||||||
|  |   content: "\e6a5"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-notification:before { | ||||||
|  |   content: "\e6a6"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-staff:before { | ||||||
|  |   content: "\e6a7"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-vip:before { | ||||||
|  |   content: "\e6a8"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-folder-add:before { | ||||||
|  |   content: "\e6a9"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-tune:before { | ||||||
|  |   content: "\e6aa"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-auth:before { | ||||||
|  |   content: "\e6ab"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-person:before { | ||||||
|  |   content: "\e699"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-email-filled:before { | ||||||
|  |   content: "\e69a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-phone-filled:before { | ||||||
|  |   content: "\e69b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-phone:before { | ||||||
|  |   content: "\e69c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-email:before { | ||||||
|  |   content: "\e69e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-personadd:before { | ||||||
|  |   content: "\e69f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-chatboxes-filled:before { | ||||||
|  |   content: "\e692"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-contact:before { | ||||||
|  |   content: "\e693"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-chatbubble-filled:before { | ||||||
|  |   content: "\e694"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-contact-filled:before { | ||||||
|  |   content: "\e695"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-chatboxes:before { | ||||||
|  |   content: "\e696"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-chatbubble:before { | ||||||
|  |   content: "\e697"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-upload-filled:before { | ||||||
|  |   content: "\e68e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-upload:before { | ||||||
|  |   content: "\e690"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-weixin:before { | ||||||
|  |   content: "\e691"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-compose:before { | ||||||
|  |   content: "\e67f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-qq:before { | ||||||
|  |   content: "\e680"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-download-filled:before { | ||||||
|  |   content: "\e681"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-pyq:before { | ||||||
|  |   content: "\e682"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-sound:before { | ||||||
|  |   content: "\e684"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-trash-filled:before { | ||||||
|  |   content: "\e685"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-sound-filled:before { | ||||||
|  |   content: "\e686"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-trash:before { | ||||||
|  |   content: "\e687"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-videocam-filled:before { | ||||||
|  |   content: "\e689"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-spinner-cycle:before { | ||||||
|  |   content: "\e68a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-weibo:before { | ||||||
|  |   content: "\e68b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-videocam:before { | ||||||
|  |   content: "\e68c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-download:before { | ||||||
|  |   content: "\e68d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-help:before { | ||||||
|  |   content: "\e679"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-navigate-filled:before { | ||||||
|  |   content: "\e67a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-plusempty:before { | ||||||
|  |   content: "\e67b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-smallcircle:before { | ||||||
|  |   content: "\e67c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-minus-filled:before { | ||||||
|  |   content: "\e67d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-micoff:before { | ||||||
|  |   content: "\e67e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-closeempty:before { | ||||||
|  |   content: "\e66c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-clear:before { | ||||||
|  |   content: "\e66d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-navigate:before { | ||||||
|  |   content: "\e66e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-minus:before { | ||||||
|  |   content: "\e66f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-image:before { | ||||||
|  |   content: "\e670"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-mic:before { | ||||||
|  |   content: "\e671"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-paperplane:before { | ||||||
|  |   content: "\e672"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-close:before { | ||||||
|  |   content: "\e673"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-help-filled:before { | ||||||
|  |   content: "\e674"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-paperplane-filled:before { | ||||||
|  |   content: "\e675"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-plus:before { | ||||||
|  |   content: "\e676"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-mic-filled:before { | ||||||
|  |   content: "\e677"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-image-filled:before { | ||||||
|  |   content: "\e678"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-locked-filled:before { | ||||||
|  |   content: "\e668"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-info:before { | ||||||
|  |   content: "\e669"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-locked:before { | ||||||
|  |   content: "\e66b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-camera-filled:before { | ||||||
|  |   content: "\e658"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-chat-filled:before { | ||||||
|  |   content: "\e659"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-camera:before { | ||||||
|  |   content: "\e65a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-circle:before { | ||||||
|  |   content: "\e65b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-checkmarkempty:before { | ||||||
|  |   content: "\e65c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-chat:before { | ||||||
|  |   content: "\e65d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-circle-filled:before { | ||||||
|  |   content: "\e65e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-flag:before { | ||||||
|  |   content: "\e65f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-flag-filled:before { | ||||||
|  |   content: "\e660"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-gear-filled:before { | ||||||
|  |   content: "\e661"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-home:before { | ||||||
|  |   content: "\e662"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-home-filled:before { | ||||||
|  |   content: "\e663"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-gear:before { | ||||||
|  |   content: "\e664"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-smallcircle-filled:before { | ||||||
|  |   content: "\e665"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-map-filled:before { | ||||||
|  |   content: "\e666"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-map:before { | ||||||
|  |   content: "\e667"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-refresh-filled:before { | ||||||
|  |   content: "\e656"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-refresh:before { | ||||||
|  |   content: "\e657"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-cloud-upload:before { | ||||||
|  |   content: "\e645"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-cloud-download-filled:before { | ||||||
|  |   content: "\e646"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-cloud-download:before { | ||||||
|  |   content: "\e647"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-cloud-upload-filled:before { | ||||||
|  |   content: "\e648"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-redo:before { | ||||||
|  |   content: "\e64a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-images-filled:before { | ||||||
|  |   content: "\e64b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-undo-filled:before { | ||||||
|  |   content: "\e64c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-more:before { | ||||||
|  |   content: "\e64d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-more-filled:before { | ||||||
|  |   content: "\e64e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-undo:before { | ||||||
|  |   content: "\e64f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-images:before { | ||||||
|  |   content: "\e650"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-paperclip:before { | ||||||
|  |   content: "\e652"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-settings:before { | ||||||
|  |   content: "\e653"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-search:before { | ||||||
|  |   content: "\e654"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-redo-filled:before { | ||||||
|  |   content: "\e655"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-list:before { | ||||||
|  |   content: "\e644"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-mail-open-filled:before { | ||||||
|  |   content: "\e63a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-hand-down-filled:before { | ||||||
|  |   content: "\e63c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-hand-down:before { | ||||||
|  |   content: "\e63d"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-hand-up-filled:before { | ||||||
|  |   content: "\e63e"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-hand-up:before { | ||||||
|  |   content: "\e63f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-heart-filled:before { | ||||||
|  |   content: "\e641"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-mail-open:before { | ||||||
|  |   content: "\e643"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-heart:before { | ||||||
|  |   content: "\e639"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-loop:before { | ||||||
|  |   content: "\e633"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-pulldown:before { | ||||||
|  |   content: "\e632"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-scan:before { | ||||||
|  |   content: "\e62a"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-bars:before { | ||||||
|  |   content: "\e627"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-cart-filled:before { | ||||||
|  |   content: "\e629"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-checkbox:before { | ||||||
|  |   content: "\e62b"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-checkbox-filled:before { | ||||||
|  |   content: "\e62c"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-shop:before { | ||||||
|  |   content: "\e62f"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-headphones:before { | ||||||
|  |   content: "\e630"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .uniui-cart:before { | ||||||
|  |   content: "\e631"; | ||||||
|  | } | ||||||
							
								
								
									
										
											BIN
										
									
								
								uni_modules/uni-icons/components/uni-icons/uniicons.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										86
									
								
								uni_modules/uni-icons/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,86 @@ | |||||||
|  | { | ||||||
|  |   "id": "uni-icons", | ||||||
|  |   "displayName": "uni-icons 图标", | ||||||
|  |   "version": "1.3.5", | ||||||
|  |   "description": "图标组件,用于展示移动端常见的图标,可自定义颜色、大小。", | ||||||
|  |   "keywords": [ | ||||||
|  |     "uni-ui", | ||||||
|  |     "uniui", | ||||||
|  |     "icon", | ||||||
|  |     "图标" | ||||||
|  | ], | ||||||
|  |   "repository": "https://github.com/dcloudio/uni-ui", | ||||||
|  |   "engines": { | ||||||
|  |     "HBuilderX": "^3.2.14" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "example": "../../temps/example_temps" | ||||||
|  |   }, | ||||||
|  |   "dcloudext": { | ||||||
|  |     "category": [ | ||||||
|  |       "前端组件", | ||||||
|  |       "通用组件" | ||||||
|  |     ], | ||||||
|  |     "sale": { | ||||||
|  |       "regular": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       }, | ||||||
|  |       "sourcecode": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "contact": { | ||||||
|  |       "qq": "" | ||||||
|  |     }, | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "无", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "dependencies": ["uni-scss"], | ||||||
|  |     "encrypt": [], | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "u", | ||||||
|  |           "联盟": "u" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |             "vue2": "y", | ||||||
|  |             "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								uni_modules/uni-icons/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,8 @@ | |||||||
|  | ## Icons 图标 | ||||||
|  | > **组件名:uni-icons** | ||||||
|  | > 代码块: `uIcons` | ||||||
|  |  | ||||||
|  | 用于展示 icons 图标 。 | ||||||
|  |  | ||||||
|  | ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-icons) | ||||||
|  | #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||||
							
								
								
									
										40
									
								
								uni_modules/uni-list/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,40 @@ | |||||||
|  | ## 1.2.10(2022-11-23) | ||||||
|  | 修复 uni-list-item 组件 keep-scroll-position 属性 无法设置为false的错误 | ||||||
|  | ## 1.2.9(2022-11-22) | ||||||
|  | - 修复 uni-list-chat 在vue3下跳转报错的bug | ||||||
|  | ## 1.2.8(2022-11-21) | ||||||
|  | - 修复 uni-list-chat avatar属性 值为本地路径时错误的问题 | ||||||
|  | ## 1.2.7(2022-11-21) | ||||||
|  | - 修复 uni-list-chat avatar属性 在腾讯云版uniCloud下错误的问题 | ||||||
|  | ## 1.2.6(2022-11-18) | ||||||
|  | - 修复 uni-list-chat note属性 支持:“草稿”字样功能 文本少1位的问题 | ||||||
|  | ## 1.2.5(2022-11-15) | ||||||
|  | - 修复 uni-list-item 的 customStyle 属性 padding值在 H5端 无效的bug | ||||||
|  | ## 1.2.4(2022-11-15) | ||||||
|  | - 修复 uni-list-item 的 customStyle 属性 padding值在nvue(vue2)下无效的bug | ||||||
|  | ## 1.2.3(2022-11-14) | ||||||
|  | - uni-list-chat 新增 avatar 支持 fileId | ||||||
|  | ## 1.2.2(2022-11-11) | ||||||
|  | - uni-list 新增属性 render-reverse 详情参考:[https://uniapp.dcloud.net.cn/component/list.html](https://uniapp.dcloud.net.cn/component/list.html) | ||||||
|  | - uni-list-chat note属性 支持:“草稿”字样 加红显示 详情参考uni-im:[https://ext.dcloud.net.cn/plugin?name=uni-im](https://ext.dcloud.net.cn/plugin?name=uni-im) | ||||||
|  | - uni-list-item 新增属性 customStyle 支持设置padding、backgroundColor | ||||||
|  | ## 1.2.1(2022-03-30) | ||||||
|  | - 删除无用文件 | ||||||
|  | ## 1.2.0(2021-11-23) | ||||||
|  | - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||||
|  | - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-list](https://uniapp.dcloud.io/component/uniui/uni-list) | ||||||
|  | ## 1.1.3(2021-08-30) | ||||||
|  | - 修复 在vue3中to属性在发行应用的时候报错的bug | ||||||
|  | ## 1.1.2(2021-07-30) | ||||||
|  | - 优化 vue3下事件警告的问题 | ||||||
|  | ## 1.1.1(2021-07-21) | ||||||
|  | - 修复 与其他组件嵌套使用时,点击失效的Bug | ||||||
|  | ## 1.1.0(2021-07-13) | ||||||
|  | - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||||
|  | ## 1.0.17(2021-05-12) | ||||||
|  | - 新增 组件示例地址 | ||||||
|  | ## 1.0.16(2021-02-05) | ||||||
|  | - 优化 组件引用关系,通过uni_modules引用组件 | ||||||
|  | ## 1.0.15(2021-02-05) | ||||||
|  | - 调整为uni_modules目录规范 | ||||||
|  | - 修复 uni-list-chat 角标显示不正常的问题 | ||||||
							
								
								
									
										107
									
								
								uni_modules/uni-list/components/uni-list-ad/uni-list-ad.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,107 @@ | |||||||
|  | <template> | ||||||
|  | 	<!-- #ifdef APP-NVUE --> | ||||||
|  | 	<cell> | ||||||
|  | 		<!-- #endif --> | ||||||
|  | 		<view class="uni-list-ad"> | ||||||
|  | 			<view v-if="borderShow" :class="{'uni-list--border':border,'uni-list-item--first':isFirstChild}"></view> | ||||||
|  | 			<ad style="width: 200px;height: 300px;border-width: 1px;border-color: red;border-style: solid;" adpid="1111111111" | ||||||
|  | 			 unit-id="" appid="" apid="" type="feed" @error="aderror" @close="closeAd"></ad> | ||||||
|  | 		</view> | ||||||
|  | 		<!-- #ifdef APP-NVUE --> | ||||||
|  | 	</cell> | ||||||
|  | 	<!-- #endif --> | ||||||
|  |  | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	// #ifdef APP-NVUE | ||||||
|  | 	const dom = uni.requireNativePlugin('dom'); | ||||||
|  | 	// #endif | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniListAd', | ||||||
|  | 		props: { | ||||||
|  | 			title: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '', | ||||||
|  |  | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		// inject: ['list'], | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				isFirstChild: false, | ||||||
|  | 				border: false, | ||||||
|  | 				borderShow: true, | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		mounted() { | ||||||
|  | 			this.list = this.getForm() | ||||||
|  | 			if (this.list) { | ||||||
|  | 				if (!this.list.firstChildAppend) { | ||||||
|  | 					this.list.firstChildAppend = true | ||||||
|  | 					this.isFirstChild = true | ||||||
|  | 				} | ||||||
|  | 				this.border = this.list.border | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			/** | ||||||
|  | 			 * 获取父元素实例 | ||||||
|  | 			 */ | ||||||
|  | 			getForm(name = 'uniList') { | ||||||
|  | 				let parent = this.$parent; | ||||||
|  | 				let parentName = parent.$options.name; | ||||||
|  | 				while (parentName !== name) { | ||||||
|  | 					parent = parent.$parent; | ||||||
|  | 					if (!parent) return false | ||||||
|  | 					parentName = parent.$options.name; | ||||||
|  | 				} | ||||||
|  | 				return parent; | ||||||
|  | 			}, | ||||||
|  | 			aderror(e) { | ||||||
|  | 				console.log("aderror: " + JSON.stringify(e.detail)); | ||||||
|  | 			}, | ||||||
|  | 			closeAd(e) { | ||||||
|  | 				this.borderShow = false | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" > | ||||||
|  | 	.uni-list-ad { | ||||||
|  | 		position: relative; | ||||||
|  | 		border: 1px red solid; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--border { | ||||||
|  | 		position: relative; | ||||||
|  | 		padding-bottom: 1px; | ||||||
|  | 		/* #ifdef APP-PLUS */ | ||||||
|  | 		border-top-color: $uni-border-color; | ||||||
|  | 		border-top-style: solid; | ||||||
|  | 		border-top-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		margin-left: $uni-spacing-row-lg; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	.uni-list--border:after { | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 0; | ||||||
|  | 		right: 0; | ||||||
|  | 		left: 0; | ||||||
|  | 		height: 1px; | ||||||
|  | 		content: ''; | ||||||
|  | 		-webkit-transform: scaleY(.5); | ||||||
|  | 		transform: scaleY(.5); | ||||||
|  | 		background-color: $uni-border-color; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item--first:after { | ||||||
|  | 		height: 0px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  | </style> | ||||||
| @@ -0,0 +1,58 @@ | |||||||
|  | /** | ||||||
|  |  * 这里是 uni-list 组件内置的常用样式变量 | ||||||
|  |  * 如果需要覆盖样式,这里提供了基本的组件样式变量,您可以尝试修改这里的变量,去完成样式替换,而不用去修改源码 | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | // 背景色 | ||||||
|  | $background-color : #fff; | ||||||
|  | // 分割线颜色 | ||||||
|  | $divide-line-color : #e5e5e5; | ||||||
|  |  | ||||||
|  | // 默认头像大小,如需要修改此值,注意同步修改 js 中的值 const avatarWidth = xx ,目前只支持方形头像 | ||||||
|  | // nvue 页面不支持修改头像大小 | ||||||
|  | $avatar-width : 45px ; | ||||||
|  |  | ||||||
|  | // 头像边框 | ||||||
|  | $avatar-border-radius: 5px; | ||||||
|  | $avatar-border-color: #eee; | ||||||
|  | $avatar-border-width: 1px; | ||||||
|  |  | ||||||
|  | // 标题文字样式 | ||||||
|  | $title-size : 16px; | ||||||
|  | $title-color : #3b4144; | ||||||
|  | $title-weight : normal; | ||||||
|  |  | ||||||
|  | // 描述文字样式 | ||||||
|  | $note-size : 12px; | ||||||
|  | $note-color : #999; | ||||||
|  | $note-weight : normal; | ||||||
|  |  | ||||||
|  | // 右侧额外内容默认样式 | ||||||
|  | $right-text-size : 12px; | ||||||
|  | $right-text-color : #999; | ||||||
|  | $right-text-weight : normal; | ||||||
|  |  | ||||||
|  | // 角标样式 | ||||||
|  | // nvue 页面不支持修改圆点位置以及大小 | ||||||
|  | // 角标在左侧时,角标的位置,默认为 0 ,负数左/下移动,正数右/上移动 | ||||||
|  | $badge-left: 0px; | ||||||
|  | $badge-top: 0px; | ||||||
|  |  | ||||||
|  | // 显示圆点时,圆点大小 | ||||||
|  | $dot-width: 10px; | ||||||
|  | $dot-height: 10px; | ||||||
|  |  | ||||||
|  | // 显示角标时,角标大小和字体大小 | ||||||
|  | $badge-size : 18px; | ||||||
|  | $badge-font : 12px; | ||||||
|  | // 显示角标时,角标前景色 | ||||||
|  | $badge-color : #fff; | ||||||
|  | // 显示角标时,角标背景色 | ||||||
|  | $badge-background-color : #ff5a5f; | ||||||
|  | // 显示角标时,角标左右间距 | ||||||
|  | $badge-space : 6px; | ||||||
|  |  | ||||||
|  | // 状态样式 | ||||||
|  | // 选中颜色 | ||||||
|  | $hover : #f5f5f5; | ||||||
							
								
								
									
										571
									
								
								uni_modules/uni-list/components/uni-list-chat/uni-list-chat.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,571 @@ | |||||||
|  | <template> | ||||||
|  | 	<!-- #ifdef APP-NVUE --> | ||||||
|  | 	<cell> | ||||||
|  | 		<!-- #endif --> | ||||||
|  | 		<view :hover-class="!clickable && !link ? '' : 'uni-list-chat--hover'" class="uni-list-chat" @click.stop="onClick"> | ||||||
|  | 			<view :class="{ 'uni-list--border': border, 'uni-list-chat--first': isFirstChild }"></view> | ||||||
|  | 			<view class="uni-list-chat__container"> | ||||||
|  | 				<view class="uni-list-chat__header-warp"> | ||||||
|  | 					<view v-if="avatarCircle || avatarList.length === 0" class="uni-list-chat__header" :class="{ 'header--circle': avatarCircle }"> | ||||||
|  | 						<image class="uni-list-chat__header-image" :class="{ 'header--circle': avatarCircle }" :src="avatarUrl" mode="aspectFill"></image> | ||||||
|  | 					</view> | ||||||
|  | 					<!-- 头像组 --> | ||||||
|  | 					<view v-else class="uni-list-chat__header"> | ||||||
|  | 						<view v-for="(item, index) in avatarList" :key="index" class="uni-list-chat__header-box" :class="computedAvatar" | ||||||
|  | 						 :style="{ width: imageWidth + 'px', height: imageWidth + 'px' }"> | ||||||
|  | 							<image class="uni-list-chat__header-image" :style="{ width: imageWidth + 'px', height: imageWidth + 'px' }" :src="item.url" | ||||||
|  | 							 mode="aspectFill"></image> | ||||||
|  | 						</view> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 				<view v-if="badgeText && badgePositon === 'left'" class="uni-list-chat__badge uni-list-chat__badge-pos" :class="[isSingle]"> | ||||||
|  | 					<text class="uni-list-chat__badge-text">{{ badgeText === 'dot' ? '' : badgeText }}</text> | ||||||
|  | 				</view> | ||||||
|  | 				<view class="uni-list-chat__content"> | ||||||
|  | 					<view class="uni-list-chat__content-main"> | ||||||
|  | 						<text class="uni-list-chat__content-title uni-ellipsis">{{ title }}</text> | ||||||
|  | 						<view style="flex-direction: row;"> | ||||||
|  | 							<text class="draft" v-if="isDraft">[草稿]</text> | ||||||
|  | 							<text class="uni-list-chat__content-note uni-ellipsis">{{isDraft?note.slice(14):note}}</text> | ||||||
|  | 						</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="uni-list-chat__content-extra"> | ||||||
|  | 						<slot> | ||||||
|  | 							<text class="uni-list-chat__content-extra-text">{{ time }}</text> | ||||||
|  | 							<view v-if="badgeText && badgePositon === 'right'" class="uni-list-chat__badge" :class="[isSingle, badgePositon === 'right' ? 'uni-list-chat--right' : '']"> | ||||||
|  | 								<text class="uni-list-chat__badge-text">{{ badgeText === 'dot' ? '' : badgeText }}</text> | ||||||
|  | 							</view> | ||||||
|  | 						</slot> | ||||||
|  | 					</view> | ||||||
|  | 				</view> | ||||||
|  | 			</view> | ||||||
|  | 		</view> | ||||||
|  | 		<!-- #ifdef APP-NVUE --> | ||||||
|  | 	</cell> | ||||||
|  | 	<!-- #endif --> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	// 头像大小 | ||||||
|  | 	const avatarWidth = 45; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * ListChat 聊天列表 | ||||||
|  | 	 * @description 聊天列表,用于创建聊天类列表 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=24 | ||||||
|  | 	 * @property {String} 	title 							标题 | ||||||
|  | 	 * @property {String} 	note 							描述 | ||||||
|  | 	 * @property {Boolean} 	clickable = [true|false] 		是否开启点击反馈,默认为false | ||||||
|  | 	 * @property {String} 	badgeText						数字角标内容 | ||||||
|  | 	 * @property {String}  	badgePositon = [left|right]		角标位置,默认为 right | ||||||
|  | 	 * @property {String} 	link = [false|navigateTo|redirectTo|reLaunch|switchTab] 是否展示右侧箭头并开启点击反馈,默认为false | ||||||
|  | 	 *  @value false	 	不开启 | ||||||
|  | 	 *  @value navigateTo 	同 uni.navigateTo() | ||||||
|  | 	 * 	@value redirectTo 	同 uni.redirectTo() | ||||||
|  | 	 * 	@value reLaunch   	同 uni.reLaunch() | ||||||
|  | 	 * 	@value switchTab  	同 uni.switchTab() | ||||||
|  | 	 * @property {String | PageURIString} 	to  			跳转目标页面 | ||||||
|  | 	 * @property {String} 	time							右侧时间显示 | ||||||
|  | 	 * @property {Boolean} 	avatarCircle = [true|false]		是否显示圆形头像,默认为false | ||||||
|  | 	 * @property {String} 	avatar							头像地址,avatarCircle 不填时生效 | ||||||
|  | 	 * @property {Array} 	avatarList 						头像组,格式为 [{url:''}] | ||||||
|  | 	 * @event {Function} 	click 							点击 uniListChat 触发事件 | ||||||
|  | 	 */ | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniListChat', | ||||||
|  | 		emits:['click'], | ||||||
|  | 		props: { | ||||||
|  | 			title: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			note: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			clickable: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			link: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			to: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			badgeText: { | ||||||
|  | 				type: [String, Number], | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			badgePositon: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: 'right' | ||||||
|  | 			}, | ||||||
|  | 			time: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			avatarCircle: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			avatar: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			avatarList: { | ||||||
|  | 				type: Array, | ||||||
|  | 				default () { | ||||||
|  | 					return []; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		// inject: ['list'], | ||||||
|  | 		computed: { | ||||||
|  | 			isDraft(){ | ||||||
|  | 				return this.note.slice(0,14) == '[uni-im-draft]' | ||||||
|  | 			}, | ||||||
|  | 			isSingle() { | ||||||
|  | 				if (this.badgeText === 'dot') { | ||||||
|  | 					return 'uni-badge--dot'; | ||||||
|  | 				} else { | ||||||
|  | 					const badgeText = this.badgeText.toString(); | ||||||
|  | 					if (badgeText.length > 1) { | ||||||
|  | 						return 'uni-badge--complex'; | ||||||
|  | 					} else { | ||||||
|  | 						return 'uni-badge--single'; | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			computedAvatar() { | ||||||
|  | 				if (this.avatarList.length > 4) { | ||||||
|  | 					this.imageWidth = avatarWidth * 0.31; | ||||||
|  | 					return 'avatarItem--3'; | ||||||
|  | 				} else if (this.avatarList.length > 1) { | ||||||
|  | 					this.imageWidth = avatarWidth * 0.47; | ||||||
|  | 					return 'avatarItem--2'; | ||||||
|  | 				} else { | ||||||
|  | 					this.imageWidth = avatarWidth; | ||||||
|  | 					return 'avatarItem--1'; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		watch: { | ||||||
|  | 			avatar:{ | ||||||
|  | 				handler(avatar) { | ||||||
|  | 					if(avatar.substr(0,8) == 'cloud://'){ | ||||||
|  | 						uniCloud.getTempFileURL({ | ||||||
|  | 							fileList: [avatar] | ||||||
|  | 						}).then(res=>{ | ||||||
|  | 							// console.log(res); | ||||||
|  | 							// 兼容uniCloud私有化部署 | ||||||
|  | 							let fileList = res.fileList || res.result.fileList | ||||||
|  | 							this.avatarUrl = fileList[0].tempFileURL | ||||||
|  | 						}) | ||||||
|  | 					}else{ | ||||||
|  | 						this.avatarUrl = avatar | ||||||
|  | 					} | ||||||
|  | 				}, | ||||||
|  | 				immediate: true | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				isFirstChild: false, | ||||||
|  | 				border: true, | ||||||
|  | 				// avatarList: 3, | ||||||
|  | 				imageWidth: 50, | ||||||
|  | 				avatarUrl:'' | ||||||
|  | 			}; | ||||||
|  | 		}, | ||||||
|  | 		mounted() { | ||||||
|  | 			this.list = this.getForm() | ||||||
|  | 			if (this.list) { | ||||||
|  | 				if (!this.list.firstChildAppend) { | ||||||
|  | 					this.list.firstChildAppend = true; | ||||||
|  | 					this.isFirstChild = true; | ||||||
|  | 				} | ||||||
|  | 				this.border = this.list.border; | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			/** | ||||||
|  | 			 * 获取父元素实例 | ||||||
|  | 			 */ | ||||||
|  | 			getForm(name = 'uniList') { | ||||||
|  | 				let parent = this.$parent; | ||||||
|  | 				let parentName = parent.$options.name; | ||||||
|  | 				while (parentName !== name) { | ||||||
|  | 					parent = parent.$parent; | ||||||
|  | 					if (!parent) return false | ||||||
|  | 					parentName = parent.$options.name; | ||||||
|  | 				} | ||||||
|  | 				return parent; | ||||||
|  | 			}, | ||||||
|  | 			onClick() { | ||||||
|  | 				if (this.to !== '') { | ||||||
|  | 					this.openPage(); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				if (this.clickable || this.link) { | ||||||
|  | 					this.$emit('click', { | ||||||
|  | 						data: {} | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			openPage() { | ||||||
|  | 				if (['navigateTo', 'redirectTo', 'reLaunch', 'switchTab'].indexOf(this.link) !== -1) { | ||||||
|  | 					this.pageApi(this.link); | ||||||
|  | 				} else { | ||||||
|  | 					this.pageApi('navigateTo'); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			pageApi(api) { | ||||||
|  | 				uni[api]({ | ||||||
|  | 					url: this.to, | ||||||
|  | 					success: res => { | ||||||
|  | 						this.$emit('click', { | ||||||
|  | 							data: res | ||||||
|  | 						}); | ||||||
|  | 					}, | ||||||
|  | 					fail: err => { | ||||||
|  | 						this.$emit('click', { | ||||||
|  | 							data: err | ||||||
|  | 						}); | ||||||
|  | 						console.error(err.errMsg); | ||||||
|  | 					} | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" > | ||||||
|  | 	$uni-font-size-lg:16px; | ||||||
|  | 	$uni-spacing-row-sm: 5px; | ||||||
|  | 	$uni-spacing-row-base: 10px; | ||||||
|  | 	$uni-spacing-row-lg: 15px; | ||||||
|  | 	$background-color: #fff; | ||||||
|  | 	$divide-line-color: #e5e5e5; | ||||||
|  | 	$avatar-width: 45px; | ||||||
|  | 	$avatar-border-radius: 5px; | ||||||
|  | 	$avatar-border-color: #eee; | ||||||
|  | 	$avatar-border-width: 1px; | ||||||
|  | 	$title-size: 16px; | ||||||
|  | 	$title-color: #3b4144; | ||||||
|  | 	$title-weight: normal; | ||||||
|  | 	$note-size: 12px; | ||||||
|  | 	$note-color: #999; | ||||||
|  | 	$note-weight: normal; | ||||||
|  | 	$right-text-size: 12px; | ||||||
|  | 	$right-text-color: #999; | ||||||
|  | 	$right-text-weight: normal; | ||||||
|  | 	$badge-left: 0px; | ||||||
|  | 	$badge-top: 0px; | ||||||
|  | 	$dot-width: 10px; | ||||||
|  | 	$dot-height: 10px; | ||||||
|  | 	$badge-size: 18px; | ||||||
|  | 	$badge-font: 12px; | ||||||
|  | 	$badge-color: #fff; | ||||||
|  | 	$badge-background-color: #ff5a5f; | ||||||
|  | 	$badge-space: 6px; | ||||||
|  | 	$hover: #f5f5f5; | ||||||
|  |  | ||||||
|  | 	.uni-list-chat { | ||||||
|  | 		font-size: $uni-font-size-lg; | ||||||
|  | 		position: relative; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		background-color: $background-color; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	// .uni-list-chat--disabled { | ||||||
|  | 	// 	opacity: 0.3; | ||||||
|  | 	// } | ||||||
|  |  | ||||||
|  | 	.uni-list-chat--hover { | ||||||
|  | 		background-color: $hover; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--border { | ||||||
|  | 		position: relative; | ||||||
|  | 		margin-left: $uni-spacing-row-lg; | ||||||
|  | 		/* #ifdef APP-PLUS */ | ||||||
|  | 		border-top-color: $divide-line-color; | ||||||
|  | 		border-top-style: solid; | ||||||
|  | 		border-top-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	.uni-list--border:after { | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 0; | ||||||
|  | 		right: 0; | ||||||
|  | 		left: 0; | ||||||
|  | 		height: 1px; | ||||||
|  | 		content: ''; | ||||||
|  | 		-webkit-transform: scaleY(0.5); | ||||||
|  | 		transform: scaleY(0.5); | ||||||
|  | 		background-color: $divide-line-color; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item--first:after { | ||||||
|  | 		height: 0px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  |  | ||||||
|  | 	.uni-list-chat--first { | ||||||
|  | 		border-top-width: 0px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-ellipsis { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		white-space: nowrap; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		lines: 1; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-ellipsis-2 { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		display: -webkit-box; | ||||||
|  | 		-webkit-line-clamp: 2; | ||||||
|  | 		-webkit-box-orient: vertical; | ||||||
|  | 		/* #endif */ | ||||||
|  |  | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		lines: 2; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__container { | ||||||
|  | 		position: relative; | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		flex: 1; | ||||||
|  | 		padding: $uni-spacing-row-base $uni-spacing-row-lg; | ||||||
|  | 		position: relative; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__header-warp { | ||||||
|  | 		position: relative; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__header { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		align-content: center; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		align-items: center; | ||||||
|  | 		flex-wrap: wrap-reverse; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		width: 50px; | ||||||
|  | 		height: 50px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		width: $avatar-width; | ||||||
|  | 		height: $avatar-width; | ||||||
|  | 		/* #endif */ | ||||||
|  |  | ||||||
|  | 		border-radius: $avatar-border-radius; | ||||||
|  | 		border-color: $avatar-border-color; | ||||||
|  | 		border-width: $avatar-border-width; | ||||||
|  | 		border-style: solid; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__header-box { | ||||||
|  | 		/* #ifndef APP-PLUS */ | ||||||
|  | 		box-sizing: border-box; | ||||||
|  | 		display: flex; | ||||||
|  | 		width: $avatar-width; | ||||||
|  | 		height: $avatar-width; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		width: 50px; | ||||||
|  | 		height: 50px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		border-radius: 2px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__header-image { | ||||||
|  | 		margin: 1px; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		width: 50px; | ||||||
|  | 		height: 50px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		width: $avatar-width; | ||||||
|  | 		height: $avatar-width; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	.uni-list-chat__header-image { | ||||||
|  | 		display: block; | ||||||
|  | 		width: 100%; | ||||||
|  | 		height: 100%; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.avatarItem--1 { | ||||||
|  | 		width: 100%; | ||||||
|  | 		height: 100%; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.avatarItem--2 { | ||||||
|  | 		width: 47%; | ||||||
|  | 		height: 47%; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.avatarItem--3 { | ||||||
|  | 		width: 32%; | ||||||
|  | 		height: 32%; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  | 	.header--circle { | ||||||
|  | 		border-radius: 50%; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__content { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		flex: 1; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		padding: 2px 0; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__content-main { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		padding-left: $uni-spacing-row-base; | ||||||
|  | 		flex: 1; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__content-title { | ||||||
|  | 		font-size: $title-size; | ||||||
|  | 		color: $title-color; | ||||||
|  | 		font-weight: $title-weight; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.draft ,.uni-list-chat__content-note { | ||||||
|  | 		margin-top: 3px; | ||||||
|  | 		color: $note-color; | ||||||
|  | 		font-size: $note-size; | ||||||
|  | 		font-weight: $title-weight; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  | 	.draft{ | ||||||
|  | 		color: #eb3a41; | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		flex-shrink: 0; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		padding-right: 3px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__content-extra { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		flex-shrink: 0; | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		align-items: flex-end; | ||||||
|  | 		margin-left: 5px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__content-extra-text { | ||||||
|  | 		color: $right-text-color; | ||||||
|  | 		font-size: $right-text-size; | ||||||
|  | 		font-weight: $right-text-weight; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__badge-pos { | ||||||
|  | 		position: absolute; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		left: 55px; | ||||||
|  | 		top: 3px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		left: calc(#{$avatar-width} + 10px - #{$badge-space} + #{$badge-left}); | ||||||
|  | 		top: calc(#{$uni-spacing-row-base}/ 2 + 1px + #{$badge-top}); | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__badge { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		justify-content: center; | ||||||
|  | 		align-items: center; | ||||||
|  | 		border-radius: 100px; | ||||||
|  | 		background-color: $badge-background-color; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat__badge-text { | ||||||
|  | 		color: $badge-color; | ||||||
|  | 		font-size: $badge-font; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-badge--single { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		// left: calc(#{$avatar-width} + 7px + #{$badge-left}); | ||||||
|  | 		/* #endif */ | ||||||
|  | 		width: $badge-size; | ||||||
|  | 		height: $badge-size; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-badge--complex { | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		left: 50px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		width: auto; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		height: $badge-size; | ||||||
|  | 		padding: 0 $badge-space; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-badge--dot { | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		left: 60px; | ||||||
|  | 		top: 6px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		left: calc(#{$avatar-width} + 15px - #{$dot-width}/ 2 + 1px + #{$badge-left}); | ||||||
|  | 		/* #endif */ | ||||||
|  | 		width: $dot-width; | ||||||
|  | 		height: $dot-height; | ||||||
|  | 		padding: 0; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-chat--right { | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		left: 0; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										530
									
								
								uni_modules/uni-list/components/uni-list-item/uni-list-item.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,530 @@ | |||||||
|  | <template> | ||||||
|  | 	<!-- #ifdef APP-NVUE --> | ||||||
|  | 	<cell :keep-scroll-position="keepScrollPosition"> | ||||||
|  | 		<!-- #endif --> | ||||||
|  | 		<view :class="{ 'uni-list-item--disabled': disabled }" :style="{'background-color':customStyle.backgroundColor}" | ||||||
|  | 			:hover-class="(!clickable && !link) || disabled || showSwitch ? '' : 'uni-list-item--hover'" | ||||||
|  | 			class="uni-list-item" @click="onClick"> | ||||||
|  | 			<view v-if="!isFirstChild" class="border--left" :class="{ 'uni-list--border': border }"></view> | ||||||
|  | 			<view class="uni-list-item__container" | ||||||
|  | 				:class="{ 'container--right': showArrow || link, 'flex--direction': direction === 'column'}" | ||||||
|  | 				:style="{paddingTop:padding.top,paddingLeft:padding.left,paddingRight:padding.right,paddingBottom:padding.bottom}"> | ||||||
|  | 				<slot name="header"> | ||||||
|  | 					<view class="uni-list-item__header"> | ||||||
|  | 						<view v-if="thumb" class="uni-list-item__icon"> | ||||||
|  | 							<image :src="thumb" class="uni-list-item__icon-img" :class="['uni-list--' + thumbSize]" /> | ||||||
|  | 						</view> | ||||||
|  | 						<view v-else-if="showExtraIcon" class="uni-list-item__icon"> | ||||||
|  | 							<uni-icons :color="extraIcon.color" :size="extraIcon.size" :type="extraIcon.type" /> | ||||||
|  | 						</view> | ||||||
|  | 					</view> | ||||||
|  | 				</slot> | ||||||
|  | 				<slot name="body"> | ||||||
|  | 					<view class="uni-list-item__content" | ||||||
|  | 						:class="{ 'uni-list-item__content--center': thumb || showExtraIcon || showBadge || showSwitch }"> | ||||||
|  | 						<text v-if="title" class="uni-list-item__content-title" | ||||||
|  | 							:class="[ellipsis !== 0 && ellipsis <= 2 ? 'uni-ellipsis-' + ellipsis : '']">{{ title }}</text> | ||||||
|  | 						<text v-if="note" class="uni-list-item__content-note">{{ note }}</text> | ||||||
|  | 					</view> | ||||||
|  | 				</slot> | ||||||
|  | 				<slot name="footer"> | ||||||
|  | 					<view v-if="rightText || showBadge || showSwitch" class="uni-list-item__extra" | ||||||
|  | 						:class="{ 'flex--justify': direction === 'column' }"> | ||||||
|  | 						<text v-if="rightText" class="uni-list-item__extra-text">{{ rightText }}</text> | ||||||
|  | 						<uni-badge v-if="showBadge" :type="badgeType" :text="badgeText" :custom-style="badgeStyle" /> | ||||||
|  | 						<switch v-if="showSwitch" :disabled="disabled" :checked="switchChecked" | ||||||
|  | 							@change="onSwitchChange" /> | ||||||
|  | 					</view> | ||||||
|  | 				</slot> | ||||||
|  | 			</view> | ||||||
|  | 			<uni-icons v-if="showArrow || link" :size="16" class="uni-icon-wrapper" color="#bbb" type="arrowright" /> | ||||||
|  | 		</view> | ||||||
|  | 		<!-- #ifdef APP-NVUE --> | ||||||
|  | 	</cell> | ||||||
|  | 	<!-- #endif --> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	/** | ||||||
|  | 	 * ListItem 列表子组件 | ||||||
|  | 	 * @description 列表子组件 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=24 | ||||||
|  | 	 * @property {String} 	title 							标题 | ||||||
|  | 	 * @property {String} 	note 							描述 | ||||||
|  | 	 * @property {String} 	thumb 							左侧缩略图,若thumb有值,则不会显示扩展图标 | ||||||
|  | 	 * @property {String}  	thumbSize = [lg|base|sm]		略缩图大小 | ||||||
|  | 	 * 	@value 	 lg			大图 | ||||||
|  | 	 * 	@value 	 base		一般 | ||||||
|  | 	 * 	@value 	 sm			小图 | ||||||
|  | 	 * @property {String} 	badgeText						数字角标内容 | ||||||
|  | 	 * @property {String} 	badgeType 						数字角标类型,参考[uni-icons](https://ext.dcloud.net.cn/plugin?id=21) | ||||||
|  | 	 * @property {Object}   badgeStyle           数字角标样式 | ||||||
|  | 	 * @property {String} 	rightText 						右侧文字内容 | ||||||
|  | 	 * @property {Boolean} 	disabled = [true|false]			是否禁用 | ||||||
|  | 	 * @property {Boolean} 	clickable = [true|false] 		是否开启点击反馈 | ||||||
|  | 	 * @property {String} 	link = [navigateTo|redirectTo|reLaunch|switchTab] 是否展示右侧箭头并开启点击反馈 | ||||||
|  | 	 *  @value 	navigateTo 	同 uni.navigateTo() | ||||||
|  | 	 * 	@value redirectTo 	同 uni.redirectTo() | ||||||
|  | 	 * 	@value reLaunch   	同 uni.reLaunch() | ||||||
|  | 	 * 	@value switchTab  	同 uni.switchTab() | ||||||
|  | 	 * @property {String | PageURIString} 	to  			跳转目标页面 | ||||||
|  | 	 * @property {Boolean} 	showBadge = [true|false] 		是否显示数字角标 | ||||||
|  | 	 * @property {Boolean} 	showSwitch = [true|false] 		是否显示Switch | ||||||
|  | 	 * @property {Boolean} 	switchChecked = [true|false] 	Switch是否被选中 | ||||||
|  | 	 * @property {Boolean} 	showExtraIcon = [true|false] 	左侧是否显示扩展图标 | ||||||
|  | 	 * @property {Object} 	extraIcon 						扩展图标参数,格式为 {color: '#4cd964',size: '22',type: 'spinner'} | ||||||
|  | 	 * @property {String} 	direction = [row|column]		排版方向 | ||||||
|  | 	 * @value row 			水平排列 | ||||||
|  | 	 * @value column 		垂直排列 | ||||||
|  | 	 * @event {Function} 	click 							点击 uniListItem 触发事件 | ||||||
|  | 	 * @event {Function} 	switchChange 					点击切换 Switch 时触发 | ||||||
|  | 	 */ | ||||||
|  | 	export default { | ||||||
|  | 		name: 'UniListItem', | ||||||
|  | 		emits: ['click', 'switchChange'], | ||||||
|  | 		props: { | ||||||
|  | 			direction: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: 'row' | ||||||
|  | 			}, | ||||||
|  | 			title: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			note: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			ellipsis: { | ||||||
|  | 				type: [Number, String], | ||||||
|  | 				default: 0 | ||||||
|  | 			}, | ||||||
|  | 			disabled: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			clickable: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			showArrow: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			link: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			to: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			showBadge: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			showSwitch: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			switchChecked: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			badgeText: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			badgeType: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: 'success' | ||||||
|  | 			}, | ||||||
|  | 			badgeStyle: { | ||||||
|  | 				type: Object, | ||||||
|  | 				default () { | ||||||
|  | 					return {} | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			rightText: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			thumb: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '' | ||||||
|  | 			}, | ||||||
|  | 			thumbSize: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: 'base' | ||||||
|  | 			}, | ||||||
|  | 			showExtraIcon: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			extraIcon: { | ||||||
|  | 				type: Object, | ||||||
|  | 				default () { | ||||||
|  | 					return { | ||||||
|  | 						type: '', | ||||||
|  | 						color: '#000000', | ||||||
|  | 						size: 20 | ||||||
|  | 					}; | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			border: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: true | ||||||
|  | 			}, | ||||||
|  | 			customStyle: { | ||||||
|  | 				type: Object, | ||||||
|  | 				default () { | ||||||
|  | 					return { | ||||||
|  | 						padding: '', | ||||||
|  | 						backgroundColor: '#FFFFFF' | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			keepScrollPosition: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		watch: { | ||||||
|  | 			'customStyle.padding': { | ||||||
|  | 				handler(padding) { | ||||||
|  | 					if(typeof padding == 'number'){ | ||||||
|  | 						padding += '' | ||||||
|  | 					} | ||||||
|  | 					let paddingArr = padding.split(' ') | ||||||
|  | 					if (paddingArr.length === 1) { | ||||||
|  | 						this.padding = { | ||||||
|  | 							"top": padding, | ||||||
|  | 							"right": padding, | ||||||
|  | 							"bottom": padding, | ||||||
|  | 							"left": padding | ||||||
|  | 						} | ||||||
|  | 					} else if (paddingArr.length === 2) { | ||||||
|  | 						this.padding = { | ||||||
|  | 							"top": padding[0], | ||||||
|  | 							"right": padding[1], | ||||||
|  | 							"bottom": padding[0], | ||||||
|  | 							"left": padding[1] | ||||||
|  | 						} | ||||||
|  | 					} else if (paddingArr.length === 4) { | ||||||
|  | 						this.padding = { | ||||||
|  | 							"top": padding[0], | ||||||
|  | 							"right": padding[1], | ||||||
|  | 							"bottom": padding[2], | ||||||
|  | 							"left": padding[3] | ||||||
|  | 						} | ||||||
|  | 					} | ||||||
|  | 				}, | ||||||
|  | 				immediate: true | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		// inject: ['list'], | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				isFirstChild: false, | ||||||
|  | 				padding: { | ||||||
|  | 					top: "", | ||||||
|  | 					right: "", | ||||||
|  | 					bottom: "", | ||||||
|  | 					left: "" | ||||||
|  | 				} | ||||||
|  | 			}; | ||||||
|  | 		}, | ||||||
|  | 		mounted() { | ||||||
|  | 			this.list = this.getForm() | ||||||
|  | 			// 判断是否存在 uni-list 组件 | ||||||
|  | 			if (this.list) { | ||||||
|  | 				if (!this.list.firstChildAppend) { | ||||||
|  | 					this.list.firstChildAppend = true; | ||||||
|  | 					this.isFirstChild = true; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			/** | ||||||
|  | 			 * 获取父元素实例 | ||||||
|  | 			 */ | ||||||
|  | 			getForm(name = 'uniList') { | ||||||
|  | 				let parent = this.$parent; | ||||||
|  | 				let parentName = parent.$options.name; | ||||||
|  | 				while (parentName !== name) { | ||||||
|  | 					parent = parent.$parent; | ||||||
|  | 					if (!parent) return false | ||||||
|  | 					parentName = parent.$options.name; | ||||||
|  | 				} | ||||||
|  | 				return parent; | ||||||
|  | 			}, | ||||||
|  | 			onClick() { | ||||||
|  | 				if (this.to !== '') { | ||||||
|  | 					this.openPage(); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				if (this.clickable || this.link) { | ||||||
|  | 					this.$emit('click', { | ||||||
|  | 						data: {} | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			onSwitchChange(e) { | ||||||
|  | 				this.$emit('switchChange', e.detail); | ||||||
|  | 			}, | ||||||
|  | 			openPage() { | ||||||
|  | 				if (['navigateTo', 'redirectTo', 'reLaunch', 'switchTab'].indexOf(this.link) !== -1) { | ||||||
|  | 					this.pageApi(this.link); | ||||||
|  | 				} else { | ||||||
|  | 					this.pageApi('navigateTo'); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			pageApi(api) { | ||||||
|  | 				let callback = { | ||||||
|  | 					url: this.to, | ||||||
|  | 					success: res => { | ||||||
|  | 						this.$emit('click', { | ||||||
|  | 							data: res | ||||||
|  | 						}); | ||||||
|  | 					}, | ||||||
|  | 					fail: err => { | ||||||
|  | 						this.$emit('click', { | ||||||
|  | 							data: err | ||||||
|  | 						}); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 				switch (api) { | ||||||
|  | 					case 'navigateTo': | ||||||
|  | 						uni.navigateTo(callback) | ||||||
|  | 						break | ||||||
|  | 					case 'redirectTo': | ||||||
|  | 						uni.redirectTo(callback) | ||||||
|  | 						break | ||||||
|  | 					case 'reLaunch': | ||||||
|  | 						uni.reLaunch(callback) | ||||||
|  | 						break | ||||||
|  | 					case 'switchTab': | ||||||
|  | 						uni.switchTab(callback) | ||||||
|  | 						break | ||||||
|  | 					default: | ||||||
|  | 						uni.navigateTo(callback) | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss"> | ||||||
|  | 	$uni-font-size-sm:12px; | ||||||
|  | 	$uni-font-size-base:14px; | ||||||
|  | 	$uni-font-size-lg:16px; | ||||||
|  | 	$uni-spacing-col-lg: 12px; | ||||||
|  | 	$uni-spacing-row-lg: 15px; | ||||||
|  | 	$uni-img-size-sm:20px; | ||||||
|  | 	$uni-img-size-base:26px; | ||||||
|  | 	$uni-img-size-lg:40px; | ||||||
|  | 	$uni-border-color:#e5e5e5; | ||||||
|  | 	$uni-bg-color-hover:#f1f1f1; | ||||||
|  | 	$uni-text-color-grey:#999; | ||||||
|  | 	$list-item-pd: $uni-spacing-col-lg $uni-spacing-row-lg; | ||||||
|  |  | ||||||
|  | 	.uni-list-item { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		font-size: $uni-font-size-lg; | ||||||
|  | 		position: relative; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		align-items: center; | ||||||
|  | 		background-color: #fff; | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		/* #ifdef H5 */ | ||||||
|  | 		cursor: pointer; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item--disabled { | ||||||
|  | 		opacity: 0.3; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item--hover { | ||||||
|  | 		background-color: $uni-bg-color-hover; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__container { | ||||||
|  | 		position: relative; | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		padding: $list-item-pd; | ||||||
|  | 		padding-left: $uni-spacing-row-lg; | ||||||
|  | 		flex: 1; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		// align-items: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.container--right { | ||||||
|  | 		padding-right: 0; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	// .border--left { | ||||||
|  | 	// 	margin-left: $uni-spacing-row-lg; | ||||||
|  | 	// } | ||||||
|  | 	.uni-list--border { | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 0; | ||||||
|  | 		right: 0; | ||||||
|  | 		left: 0; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		border-top-color: $uni-border-color; | ||||||
|  | 		border-top-style: solid; | ||||||
|  | 		border-top-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	.uni-list--border:after { | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 0; | ||||||
|  | 		right: 0; | ||||||
|  | 		left: 0; | ||||||
|  | 		height: 1px; | ||||||
|  | 		content: ''; | ||||||
|  | 		-webkit-transform: scaleY(0.5); | ||||||
|  | 		transform: scaleY(0.5); | ||||||
|  | 		background-color: $uni-border-color; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  | 	.uni-list-item__content { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		padding-right: 8px; | ||||||
|  | 		flex: 1; | ||||||
|  | 		color: #3b4144; | ||||||
|  | 		// overflow: hidden; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__content--center { | ||||||
|  | 		justify-content: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__content-title { | ||||||
|  | 		font-size: $uni-font-size-base; | ||||||
|  | 		color: #3b4144; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__content-note { | ||||||
|  | 		margin-top: 6rpx; | ||||||
|  | 		color: $uni-text-color-grey; | ||||||
|  | 		font-size: $uni-font-size-sm; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__extra { | ||||||
|  | 		// width: 25%; | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		justify-content: flex-end; | ||||||
|  | 		align-items: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__header { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		align-items: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__icon { | ||||||
|  | 		margin-right: 18rpx; | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		align-items: center; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__icon-img { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: block; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		height: $uni-img-size-base; | ||||||
|  | 		width: $uni-img-size-base; | ||||||
|  | 		margin-right: 10px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-icon-wrapper { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		align-items: center; | ||||||
|  | 		padding: 0 10px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.flex--direction { | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		align-items: initial; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.flex--justify { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		justify-content: initial; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--lg { | ||||||
|  | 		height: $uni-img-size-lg; | ||||||
|  | 		width: $uni-img-size-lg; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--base { | ||||||
|  | 		height: $uni-img-size-base; | ||||||
|  | 		width: $uni-img-size-base; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--sm { | ||||||
|  | 		height: $uni-img-size-sm; | ||||||
|  | 		width: $uni-img-size-sm; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list-item__extra-text { | ||||||
|  | 		color: $uni-text-color-grey; | ||||||
|  | 		font-size: $uni-font-size-sm; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-ellipsis-1 { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		white-space: nowrap; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		lines: 1; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-ellipsis-2 { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		display: -webkit-box; | ||||||
|  | 		-webkit-line-clamp: 2; | ||||||
|  | 		-webkit-box-orient: vertical; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		lines: 2; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										123
									
								
								uni_modules/uni-list/components/uni-list/uni-list.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,123 @@ | |||||||
|  | <template> | ||||||
|  | 	<!-- #ifndef APP-NVUE --> | ||||||
|  | 	<view class="uni-list uni-border-top-bottom"> | ||||||
|  | 		<view v-if="border" class="uni-list--border-top"></view> | ||||||
|  | 		<slot /> | ||||||
|  | 		<view v-if="border" class="uni-list--border-bottom"></view> | ||||||
|  | 	</view> | ||||||
|  | 	<!-- #endif --> | ||||||
|  | 	<!-- #ifdef APP-NVUE --> | ||||||
|  | 	<list :bounce="false" :scrollable="true" show-scrollbar :render-reverse="renderReverse" @scroll="scroll" class="uni-list" :class="{ 'uni-list--border': border }" :enableBackToTop="enableBackToTop" | ||||||
|  | 		loadmoreoffset="15"> | ||||||
|  | 		<slot /> | ||||||
|  | 	</list> | ||||||
|  | 	<!-- #endif --> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	/** | ||||||
|  | 	 * List 列表 | ||||||
|  | 	 * @description 列表组件 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=24 | ||||||
|  | 	 * @property {String} 	border = [true|false] 		标题 | ||||||
|  | 	 */ | ||||||
|  | 	export default { | ||||||
|  | 		name: 'uniList', | ||||||
|  | 		'mp-weixin': { | ||||||
|  | 			options: { | ||||||
|  | 				multipleSlots: false | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		props: { | ||||||
|  | 			stackFromEnd:{ | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default:false | ||||||
|  | 			}, | ||||||
|  | 			enableBackToTop: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			scrollY: { | ||||||
|  | 				type: [Boolean, String], | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			border: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: true | ||||||
|  | 			}, | ||||||
|  | 			renderReverse:{ | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		// provide() { | ||||||
|  | 		// 	return { | ||||||
|  | 		// 		list: this | ||||||
|  | 		// 	}; | ||||||
|  | 		// }, | ||||||
|  | 		created() { | ||||||
|  | 			this.firstChildAppend = false; | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			loadMore(e) { | ||||||
|  | 				this.$emit('scrolltolower'); | ||||||
|  | 			}, | ||||||
|  | 			scroll(e) { | ||||||
|  | 				this.$emit('scroll', e); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  | </script> | ||||||
|  | <style lang="scss"> | ||||||
|  | 	$uni-bg-color:#ffffff; | ||||||
|  | 	$uni-border-color:#e5e5e5; | ||||||
|  |  | ||||||
|  | 	.uni-list { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		background-color: $uni-bg-color; | ||||||
|  | 		position: relative; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--border { | ||||||
|  | 		position: relative; | ||||||
|  | 		/* #ifdef APP-NVUE */ | ||||||
|  | 		border-top-color: $uni-border-color; | ||||||
|  | 		border-top-style: solid; | ||||||
|  | 		border-top-width: 0.5px; | ||||||
|  | 		border-bottom-color: $uni-border-color; | ||||||
|  | 		border-bottom-style: solid; | ||||||
|  | 		border-bottom-width: 0.5px; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		z-index: -1; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  |  | ||||||
|  | 	.uni-list--border-top { | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 0; | ||||||
|  | 		right: 0; | ||||||
|  | 		left: 0; | ||||||
|  | 		height: 1px; | ||||||
|  | 		-webkit-transform: scaleY(0.5); | ||||||
|  | 		transform: scaleY(0.5); | ||||||
|  | 		background-color: $uni-border-color; | ||||||
|  | 		z-index: 1; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-list--border-bottom { | ||||||
|  | 		position: absolute; | ||||||
|  | 		bottom: 0; | ||||||
|  | 		right: 0; | ||||||
|  | 		left: 0; | ||||||
|  | 		height: 1px; | ||||||
|  | 		-webkit-transform: scaleY(0.5); | ||||||
|  | 		transform: scaleY(0.5); | ||||||
|  | 		background-color: $uni-border-color; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* #endif */ | ||||||
|  | </style> | ||||||
							
								
								
									
										65
									
								
								uni_modules/uni-list/components/uni-list/uni-refresh.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,65 @@ | |||||||
|  | <template> | ||||||
|  |     <!-- #ifdef APP-NVUE --> | ||||||
|  |     <refresh :display="display" @refresh="onrefresh" @pullingdown="onpullingdown"> | ||||||
|  |         <slot /> | ||||||
|  |     </refresh> | ||||||
|  |     <!-- #endif --> | ||||||
|  |     <!-- #ifndef APP-NVUE --> | ||||||
|  |     <view ref="uni-refresh" class="uni-refresh" v-show="isShow"> | ||||||
|  |         <slot /> | ||||||
|  |     </view> | ||||||
|  |     <!-- #endif --> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  |     export default { | ||||||
|  |         name: 'UniRefresh', | ||||||
|  |         props: { | ||||||
|  |             display: { | ||||||
|  |                 type: [String], | ||||||
|  |                 default: "hide" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         data() { | ||||||
|  |             return { | ||||||
|  |                 pulling: false | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         computed: { | ||||||
|  |             isShow() { | ||||||
|  |                 if (this.display === "show" || this.pulling === true) { | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         created() {}, | ||||||
|  |         methods: { | ||||||
|  |             onchange(value) { | ||||||
|  |                 this.pulling = value; | ||||||
|  |             }, | ||||||
|  |             onrefresh(e) { | ||||||
|  |                 this.$emit("refresh", e); | ||||||
|  |             }, | ||||||
|  |             onpullingdown(e) { | ||||||
|  |                 // #ifdef APP-NVUE | ||||||
|  |                 this.$emit("pullingdown", e); | ||||||
|  |                 // #endif | ||||||
|  |                 // #ifndef APP-NVUE | ||||||
|  |                 var detail = { | ||||||
|  |                     viewHeight: 90, | ||||||
|  |                     pullingDistance: e.height | ||||||
|  |                 } | ||||||
|  |                 this.$emit("pullingdown", detail); | ||||||
|  |                 // #endif | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  |     .uni-refresh { | ||||||
|  |         height: 0; | ||||||
|  |         overflow: hidden; | ||||||
|  |     } | ||||||
|  | </style> | ||||||
							
								
								
									
										87
									
								
								uni_modules/uni-list/components/uni-list/uni-refresh.wxs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,87 @@ | |||||||
|  | var pullDown = { | ||||||
|  |     threshold: 95, | ||||||
|  |     maxHeight: 200, | ||||||
|  |     callRefresh: 'onrefresh', | ||||||
|  |     callPullingDown: 'onpullingdown', | ||||||
|  |     refreshSelector: '.uni-refresh' | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | function ready(newValue, oldValue, ownerInstance, instance) { | ||||||
|  |     var state = instance.getState() | ||||||
|  |     state.canPullDown = newValue; | ||||||
|  |     // console.log(newValue); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function touchStart(e, instance) { | ||||||
|  |     var state = instance.getState(); | ||||||
|  |     state.refreshInstance = instance.selectComponent(pullDown.refreshSelector); | ||||||
|  |     state.canPullDown = (state.refreshInstance != null && state.refreshInstance != undefined); | ||||||
|  |     if (!state.canPullDown) { | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // console.log("touchStart"); | ||||||
|  |  | ||||||
|  |     state.height = 0; | ||||||
|  |     state.touchStartY = e.touches[0].pageY || e.changedTouches[0].pageY; | ||||||
|  |     state.refreshInstance.setStyle({ | ||||||
|  |         'height': 0 | ||||||
|  |     }); | ||||||
|  |     state.refreshInstance.callMethod("onchange", true); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function touchMove(e, ownerInstance) { | ||||||
|  |     var instance = e.instance; | ||||||
|  |     var state = instance.getState(); | ||||||
|  |     if (!state.canPullDown) { | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     var oldHeight = state.height; | ||||||
|  |     var endY = e.touches[0].pageY || e.changedTouches[0].pageY; | ||||||
|  |     var height = endY - state.touchStartY; | ||||||
|  |     if (height > pullDown.maxHeight) { | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     var refreshInstance = state.refreshInstance; | ||||||
|  |     refreshInstance.setStyle({ | ||||||
|  |         'height': height + 'px' | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     height = height < pullDown.maxHeight ? height : pullDown.maxHeight; | ||||||
|  |     state.height = height; | ||||||
|  |     refreshInstance.callMethod(pullDown.callPullingDown, { | ||||||
|  |         height: height | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function touchEnd(e, ownerInstance) { | ||||||
|  |     var state = e.instance.getState(); | ||||||
|  |     if (!state.canPullDown) { | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     state.refreshInstance.callMethod("onchange", false); | ||||||
|  |  | ||||||
|  |     var refreshInstance = state.refreshInstance; | ||||||
|  |     if (state.height > pullDown.threshold) { | ||||||
|  |         refreshInstance.callMethod(pullDown.callRefresh); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     refreshInstance.setStyle({ | ||||||
|  |         'height': 0 | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function propObserver(newValue, oldValue, instance) { | ||||||
|  |     pullDown = newValue; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | module.exports = { | ||||||
|  |     touchmove: touchMove, | ||||||
|  |     touchstart: touchStart, | ||||||
|  |     touchend: touchEnd, | ||||||
|  |     propObserver: propObserver | ||||||
|  | } | ||||||
							
								
								
									
										88
									
								
								uni_modules/uni-list/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,88 @@ | |||||||
|  | { | ||||||
|  |   "id": "uni-list", | ||||||
|  |   "displayName": "uni-list 列表", | ||||||
|  |   "version": "1.2.10", | ||||||
|  |   "description": "List 组件 ,帮助使用者快速构建列表。", | ||||||
|  |   "keywords": [ | ||||||
|  |     "", | ||||||
|  |     "uni-ui", | ||||||
|  |     "uniui", | ||||||
|  |     "列表", | ||||||
|  |     "", | ||||||
|  |     "list" | ||||||
|  | ], | ||||||
|  |   "repository": "https://github.com/dcloudio/uni-ui", | ||||||
|  |   "engines": { | ||||||
|  |     "HBuilderX": "" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "example": "../../temps/example_temps" | ||||||
|  |   }, | ||||||
|  | "dcloudext": { | ||||||
|  |     "sale": { | ||||||
|  |       "regular": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       }, | ||||||
|  |       "sourcecode": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "contact": { | ||||||
|  |       "qq": "" | ||||||
|  |     }, | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "无", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui", | ||||||
|  |     "type": "component-vue" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "dependencies": [ | ||||||
|  |       "uni-badge", | ||||||
|  |       "uni-icons" | ||||||
|  |     ], | ||||||
|  |     "encrypt": [], | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "u", | ||||||
|  |           "联盟": "u" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |             "vue2": "y", | ||||||
|  |             "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										346
									
								
								uni_modules/uni-list/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,346 @@ | |||||||
|  | ## List 列表 | ||||||
|  | > **组件名:uni-list** | ||||||
|  | > 代码块: `uList`、`uListItem` | ||||||
|  | > 关联组件:`uni-list-item`、`uni-badge`、`uni-icons`、`uni-list-chat`、`uni-list-ad` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | List 列表组件,包含基本列表样式、可扩展插槽机制、长列表性能优化、多端兼容。 | ||||||
|  |  | ||||||
|  | 在vue页面里,它默认使用页面级滚动。在app-nvue页面里,它默认使用原生list组件滚动。这样的长列表,在滚动出屏幕外后,系统会回收不可见区域的渲染内存资源,不会造成滚动越长手机越卡的问题。 | ||||||
|  |  | ||||||
|  | uni-list组件是父容器,里面的核心是uni-list-item子组件,它代表列表中的一个可重复行,子组件可以无限循环。 | ||||||
|  |  | ||||||
|  | uni-list-item有很多风格,uni-list-item组件通过内置的属性,满足一些常用的场景。当内置属性不满足需求时,可以通过扩展插槽来自定义列表内容。 | ||||||
|  |  | ||||||
|  | 内置属性可以覆盖的场景包括:导航列表、设置列表、小图标列表、通信录列表、聊天记录列表。 | ||||||
|  |  | ||||||
|  | 涉及很多大图或丰富内容的列表,比如类今日头条的新闻列表、类淘宝的电商列表,需要通过扩展插槽实现。 | ||||||
|  |  | ||||||
|  | 下文均有样例给出。 | ||||||
|  |  | ||||||
|  | uni-list不包含下拉刷新和上拉翻页。上拉翻页另见组件:[uni-load-more](https://ext.dcloud.net.cn/plugin?id=29) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### 安装方式 | ||||||
|  |  | ||||||
|  | 本组件符合[easycom](https://uniapp.dcloud.io/collocation/pages?id=easycom)规范,`HBuilderX 2.5.5`起,只需将本组件导入项目,在页面`template`中即可直接使用,无需在页面中`import`和注册`components`。 | ||||||
|  |  | ||||||
|  | 如需通过`npm`方式使用`uni-ui`组件,另见文档:[https://ext.dcloud.net.cn/plugin?id=55](https://ext.dcloud.net.cn/plugin?id=55) | ||||||
|  |  | ||||||
|  | > **注意事项** | ||||||
|  | > 为了避免错误使用,给大家带来不好的开发体验,请在使用组件前仔细阅读下面的注意事项,可以帮你避免一些错误。 | ||||||
|  | > - 组件需要依赖 `sass` 插件 ,请自行手动安装 | ||||||
|  | > - 组件内部依赖 `'uni-icons'` 、`uni-badge` 组件 | ||||||
|  | > - `uni-list` 和 `uni-list-item` 需要配套使用,暂不支持单独使用 `uni-list-item` | ||||||
|  | > - 只有开启点击反馈后,会有点击选中效果 | ||||||
|  | > - 使用插槽时,可以完全自定义内容 | ||||||
|  | > - note 、rightText 属性暂时没做限制,不支持文字溢出隐藏,使用时应该控制长度显示或通过默认插槽自行扩展 | ||||||
|  | > - 支付宝小程序平台需要在支付宝小程序开发者工具里开启 component2 编译模式,开启方式: 详情 --> 项目配置 --> 启用 component2 编译 | ||||||
|  | > - 如果需要修改 `switch`、`badge` 样式,请使用插槽自定义 | ||||||
|  | > - 在 `HBuilderX` 低版本中,可能会出现组件显示 `undefined` 的问题,请升级最新的 `HBuilderX` 或者 `cli` | ||||||
|  | > - 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839 | ||||||
|  |   | ||||||
|  |  | ||||||
|  | ### 基本用法  | ||||||
|  |  | ||||||
|  | - 设置 `title` 属性,可以显示列表标题 | ||||||
|  | - 设置 `disabled` 属性,可以禁用当前项 | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  | <uni-list> | ||||||
|  | 	<uni-list-item  title="列表文字" ></uni-list-item> | ||||||
|  | 	<uni-list-item :disabled="true" title="列表禁用状态" ></uni-list-item> | ||||||
|  | </uni-list> | ||||||
|  | 			  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### 多行内容显示 | ||||||
|  |  | ||||||
|  | - 设置 `note` 属性 ,可以在第二行显示描述文本信息 | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  | <uni-list> | ||||||
|  | 	<uni-list-item title="列表文字" note="列表描述信息"></uni-list-item> | ||||||
|  | 	<uni-list-item :disabled="true" title="列表文字" note="列表禁用状态"></uni-list-item> | ||||||
|  | </uni-list> | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### 右侧显示角标、switch | ||||||
|  |  | ||||||
|  | - 设置 `show-badge` 属性 ,可以显示角标内容 | ||||||
|  | - 设置 `show-switch` 属性,可以显示 switch 开关 | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  | <uni-list> | ||||||
|  | 	<uni-list-item  title="列表右侧显示角标" :show-badge="true" badge-text="12" ></uni-list-item> | ||||||
|  | 	<uni-list-item title="列表右侧显示 switch"  :show-switch="true"  @switchChange="switchChange" ></uni-list-item> | ||||||
|  | </uni-list> | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### 左侧显示略缩图、图标   | ||||||
|  |  | ||||||
|  | - 设置 `thumb` 属性 ,可以在列表左侧显示略缩图 | ||||||
|  | - 设置 `show-extra-icon` 属性,并指定 `extra-icon` 可以在左侧显示图标 | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  |  <uni-list> | ||||||
|  |  	<uni-list-item title="列表左侧带略缩图" note="列表描述信息" thumb="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" | ||||||
|  |  	 thumb-size="lg" rightText="右侧文字"></uni-list-item> | ||||||
|  |  	<uni-list-item :show-extra-icon="true" :extra-icon="extraIcon1" title="列表左侧带扩展图标" ></uni-list-item> | ||||||
|  | </uni-list> | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### 开启点击反馈和右侧箭头 | ||||||
|  | - 设置 `clickable` 为 `true` ,则表示这是一个可点击的列表,会默认给一个点击效果,并可以监听 `click` 事件 | ||||||
|  | - 设置 `link` 属性,会自动开启点击反馈,并给列表右侧添加一个箭头 | ||||||
|  | - 设置 `to` 属性,可以跳转页面,`link` 的值表示跳转方式,如果不指定,默认为 `navigateTo` | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  |  | ||||||
|  | <uni-list> | ||||||
|  | 	<uni-list-item title="开启点击反馈" clickable  @click="onClick" ></uni-list-item> | ||||||
|  | 	<uni-list-item title="默认 navigateTo 方式跳转页面" link to="/pages/vue/index/index" @click="onClick($event,1)" ></uni-list-item> | ||||||
|  | 	<uni-list-item title="reLaunch 方式跳转页面" link="reLaunch" to="/pages/vue/index/index" @click="onClick($event,1)" ></uni-list-item> | ||||||
|  | </uni-list> | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### 聊天列表示例 | ||||||
|  | - 设置 `clickable` 为 `true` ,则表示这是一个可点击的列表,会默认给一个点击效果,并可以监听 `click` 事件 | ||||||
|  | - 设置 `link` 属性,会自动开启点击反馈,`link` 的值表示跳转方式,如果不指定,默认为 `navigateTo` | ||||||
|  | - 设置 `to` 属性,可以跳转页面 | ||||||
|  | - `time` 属性,通常会设置成时间显示,但是这个属性不仅仅可以设置时间,你可以传入任何文本,注意文本长度可能会影响显示 | ||||||
|  | - `avatar` 和 `avatarList` 属性同时只会有一个生效,同时设置的话,`avatarList` 属性的长度大于1 ,`avatar` 属性将失效 | ||||||
|  | - 可以通过默认插槽自定义列表右侧内容 | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  |  | ||||||
|  | <uni-list> | ||||||
|  | 	<uni-list :border="true"> | ||||||
|  | 		<!-- 显示圆形头像 --> | ||||||
|  | 		<uni-list-chat :avatar-circle="true" title="uni-app" avatar="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" note="您收到一条新的消息" time="2020-02-02 20:20" ></uni-list-chat> | ||||||
|  | 		<!-- 右侧带角标 --> | ||||||
|  | 		<uni-list-chat title="uni-app" avatar="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" note="您收到一条新的消息" time="2020-02-02 20:20" badge-text="12" :badge-style="{backgroundColor:'#FF80AB'}"></uni-list-chat> | ||||||
|  | 		<!-- 头像显示圆点 --> | ||||||
|  | 		<uni-list-chat title="uni-app" avatar="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" note="您收到一条新的消息" time="2020-02-02 20:20" badge-positon="left" badge-text="dot"></uni-list-chat> | ||||||
|  | 		<!-- 头像显示角标 --> | ||||||
|  | 		<uni-list-chat title="uni-app" avatar="https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png" note="您收到一条新的消息" time="2020-02-02 20:20" badge-positon="left" badge-text="99"></uni-list-chat> | ||||||
|  | 		<!-- 显示多头像 --> | ||||||
|  | 		<uni-list-chat title="uni-app" :avatar-list="avatarList" note="您收到一条新的消息" time="2020-02-02 20:20" badge-positon="left" badge-text="dot"></uni-list-chat> | ||||||
|  | 		<!-- 自定义右侧内容 --> | ||||||
|  | 		<uni-list-chat title="uni-app" :avatar-list="avatarList" note="您收到一条新的消息" time="2020-02-02 20:20" badge-positon="left" badge-text="dot"> | ||||||
|  | 			<view class="chat-custom-right"> | ||||||
|  | 				<text class="chat-custom-text">刚刚</text> | ||||||
|  | 				<!-- 需要使用 uni-icons 请自行引入 --> | ||||||
|  | 				<uni-icons type="star-filled" color="#999" size="18"></uni-icons> | ||||||
|  | 			</view> | ||||||
|  | 		</uni-list-chat> | ||||||
|  | 	</uni-list> | ||||||
|  | </uni-list> | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ```javascript | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  | 	components: {}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			avatarList: [{ | ||||||
|  | 				url: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png' | ||||||
|  | 			}, { | ||||||
|  | 				url: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png' | ||||||
|  | 			}, { | ||||||
|  | 				url: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/460d46d0-4fcc-11eb-8ff1-d5dcf8779628.png' | ||||||
|  | 			}] | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ```css | ||||||
|  |  | ||||||
|  | .chat-custom-right { | ||||||
|  | 	flex: 1; | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	display: flex; | ||||||
|  | 	/* #endif */ | ||||||
|  | 	flex-direction: column; | ||||||
|  | 	justify-content: space-between; | ||||||
|  | 	align-items: flex-end; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .chat-custom-text { | ||||||
|  | 	font-size: 12px; | ||||||
|  | 	color: #999; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## API | ||||||
|  |  | ||||||
|  | ### List Props | ||||||
|  |  | ||||||
|  | 属性名			|类型		|默认值		|	说明																									 | ||||||
|  | :-:				|:-:		|:-:		|	:-:	 | ||||||
|  | border			|Boolean	|true		|	是否显示边框 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### ListItem Props | ||||||
|  |  | ||||||
|  | 属性名			|类型		|默认值		|	说明																					 | ||||||
|  | :-:				|:-:		|:-:		|	:-:	 | ||||||
|  | title			|String		|-			|	标题 | ||||||
|  | note			|String		|-			|	描述 | ||||||
|  | ellipsis		|Number		|0			|	title 是否溢出隐藏,可选值,0:默认;  1:显示一行;	2:显示两行;【nvue 暂不支持】 | ||||||
|  | thumb			|String		|-			|	左侧缩略图,若thumb有值,则不会显示扩展图标 | ||||||
|  | thumbSize		|String 	|medium 	|	略缩图尺寸,可选值,lg:大图;  medium:一般;	sm:小图; | ||||||
|  | showBadge		|Boolean	|false		|	是否显示数字角标	 | ||||||
|  | badgeText		|String		|-			|	数字角标内容 | ||||||
|  | badgeType		|String		|-			|	数字角标类型,参考[uni-icons](https://ext.dcloud.net.cn/plugin?id=21)	 | ||||||
|  | badgeStyle  |Object   |-      | 数字角标样式,使用uni-badge的custom-style参数 | ||||||
|  | rightText		|String		|-			|	右侧文字内容 | ||||||
|  | disabled		|Boolean	|false		|	是否禁用	 | ||||||
|  | showArrow 		|Boolean	|true		|	是否显示箭头图标			 | ||||||
|  | link			|String 	|navigateTo	|	新页面跳转方式,可选值见下表 | ||||||
|  | to				|String		|-			|	新页面跳转地址,如填写此属性,click 会返回页面是否跳转成功			 | ||||||
|  | clickable		|Boolean	|false		|	是否开启点击反馈 | ||||||
|  | showSwitch	    |Boolean	|false		|	是否显示Switch																			 | ||||||
|  | switchChecked	|Boolean	|false		|	Switch是否被选中																			 | ||||||
|  | showExtraIcon   |Boolean	|false		|	左侧是否显示扩展图标																		 | ||||||
|  | extraIcon		|Object		|-			|	扩展图标参数,格式为 ``{color: '#4cd964',size: '22',type: 'spinner'}``,参考 [uni-icons](https://ext.dcloud.net.cn/plugin?id=28)	 | ||||||
|  | direction		| String	|row		|	排版方向,可选值,row:水平排列;  column:垂直排列; 3个插槽是水平排还是垂直排,也受此属性控制 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #### Link Options | ||||||
|  |  | ||||||
|  | 属性名				|	说明 | ||||||
|  | :-:					|	:-: | ||||||
|  | navigateTo 	| 	同 uni.navigateTo() | ||||||
|  | redirectTo 	|	同 uni.reLaunch() | ||||||
|  | reLaunch		|	同 uni.reLaunch() | ||||||
|  | switchTab  	|	同 uni.switchTab() | ||||||
|  |  | ||||||
|  | ### ListItem Events | ||||||
|  |  | ||||||
|  | 事件称名			|说明									|返回参数			 | ||||||
|  | :-:				|:-:									|:-:				 | ||||||
|  | click			|点击 uniListItem 触发事件,需开启点击反馈	|-					 | ||||||
|  | switchChange	|点击切换 Switch 时触发,需显示 switch		|e={value:checked}	 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### ListItem Slots | ||||||
|  |  | ||||||
|  | 名称	 	|	说明					 | ||||||
|  | :-:		|	:-:						 | ||||||
|  | header	|	左/上内容插槽,可完全自定义默认显示 | ||||||
|  | body	|	中间内容插槽,可完全自定义中间内容				 | ||||||
|  | footer	|	右/下内容插槽,可完全自定义右侧内容		 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | > **通过插槽扩展** | ||||||
|  | > 需要注意的是当使用插槽时,内置样式将会失效,只保留排版样式,此时的样式需要开发者自己实现 | ||||||
|  | > 如果	`uni-list-item` 组件内置属性样式无法满足需求,可以使用插槽来自定义uni-list-item里的内容。 | ||||||
|  | > uni-list-item提供了3个可扩展的插槽:`header`、`body`、`footer` | ||||||
|  | > - 当 `direction` 属性为 `row` 时表示水平排列,此时 `header` 表示列表的左边部分,`body` 表示列表的中间部分,`footer` 表示列表的右边部分 | ||||||
|  | > - 当 `direction` 属性为 `column` 时表示垂直排列,此时 `header` 表示列表的上边部分,`body` 表示列表的中间部分,`footer` 表示列表的下边部分 | ||||||
|  | > 开发者可以只用1个插槽,也可以3个一起使用。在插槽中可自主编写view标签,实现自己所需的效果。 | ||||||
|  |  | ||||||
|  | 	 | ||||||
|  | **示例** | ||||||
|  |  | ||||||
|  | ```html | ||||||
|  | <uni-list> | ||||||
|  | 	<uni-list-item title="自定义右侧插槽" note="列表描述信息" link> | ||||||
|  | 		<template slot="header"> | ||||||
|  | 			<image class="slot-image" src="/static/logo.png" mode="widthFix"></image> | ||||||
|  | 		</template> | ||||||
|  | 	</uni-list-item> | ||||||
|  | 	<uni-list-item> | ||||||
|  | 		<!-- 自定义 header --> | ||||||
|  | 		<view slot="header" class="slot-box"><image class="slot-image" src="/static/logo.png" mode="widthFix"></image></view> | ||||||
|  | 		<!-- 自定义 body --> | ||||||
|  | 		<text slot="body" class="slot-box slot-text">自定义插槽</text> | ||||||
|  | 		<!-- 自定义 footer--> | ||||||
|  | 		<template slot="footer"> | ||||||
|  | 			<image class="slot-image" src="/static/logo.png" mode="widthFix"></image> | ||||||
|  | 		</template> | ||||||
|  | 	</uni-list-item> | ||||||
|  | </uni-list> | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### ListItemChat Props | ||||||
|  |  | ||||||
|  | 属性名			|类型		|默认值		|	说明																		 | ||||||
|  | :-:				|:-:		|:-:		|	:-:	 | ||||||
|  | title 			|String		|-			|	标题 | ||||||
|  | note 			|String		|-			|	描述 | ||||||
|  | clickable		|Boolean	|false		|	是否开启点击反馈 | ||||||
|  | badgeText		|String		|-			|	数字角标内容,设置为 `dot` 将显示圆点 | ||||||
|  | badgePositon 	|String		|right		|	角标位置 | ||||||
|  | link			|String 	|navigateTo	|	是否展示右侧箭头并开启点击反馈,可选值见下表 | ||||||
|  | clickable		|Boolean	|false		|	是否开启点击反馈 | ||||||
|  | to				|String		|-			|	跳转页面地址,如填写此属性,click 会返回页面是否跳转成功	 | ||||||
|  | time			|String 	|-			|	右侧时间显示 | ||||||
|  | avatarCircle 	|Boolean 	|false		|	是否显示圆形头像 | ||||||
|  | avatar			|String 	|-			|	头像地址,avatarCircle 不填时生效 | ||||||
|  | avatarList 		|Array	 	|-			|	头像组,格式为 [{url:''}] | ||||||
|  |  | ||||||
|  | #### Link Options | ||||||
|  |  | ||||||
|  | 属性名		|	说明 | ||||||
|  | :-:			|	:-: | ||||||
|  | navigateTo 	| 	同 uni.navigateTo() | ||||||
|  | redirectTo 	|	同 uni.reLaunch() | ||||||
|  | reLaunch	|	同 uni.reLaunch() | ||||||
|  | switchTab  	|	同 uni.switchTab() | ||||||
|  |  | ||||||
|  | ### ListItemChat Slots | ||||||
|  |  | ||||||
|  | 名称	 	|	说明					 | ||||||
|  | :-		|	:-						 | ||||||
|  | default	|	自定义列表右侧内容(包括时间和角标显示) | ||||||
|  |  | ||||||
|  | ### ListItemChat Events | ||||||
|  | 事件称名			|	说明						|	返回参数			 | ||||||
|  | :-:				|	:-:						|	:-:	 | ||||||
|  | @click			|	点击 uniListChat 触发事件	|	{data:{}}	,如有 to 属性,会返回页面跳转信息	 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## 基于uni-list扩展的页面模板 | ||||||
|  |  | ||||||
|  | 通过扩展插槽,可实现多种常见样式的列表 | ||||||
|  |  | ||||||
|  | **新闻列表类** | ||||||
|  |  | ||||||
|  | 1. 云端一体混合布局:[https://ext.dcloud.net.cn/plugin?id=2546](https://ext.dcloud.net.cn/plugin?id=2546) | ||||||
|  | 2. 云端一体垂直布局,大图模式:[https://ext.dcloud.net.cn/plugin?id=2583](https://ext.dcloud.net.cn/plugin?id=2583) | ||||||
|  | 3. 云端一体垂直布局,多行图文混排:[https://ext.dcloud.net.cn/plugin?id=2584](https://ext.dcloud.net.cn/plugin?id=2584) | ||||||
|  | 4. 云端一体垂直布局,多图模式:[https://ext.dcloud.net.cn/plugin?id=2585](https://ext.dcloud.net.cn/plugin?id=2585) | ||||||
|  | 5. 云端一体水平布局,左图右文:[https://ext.dcloud.net.cn/plugin?id=2586](https://ext.dcloud.net.cn/plugin?id=2586) | ||||||
|  | 6. 云端一体水平布局,左文右图:[https://ext.dcloud.net.cn/plugin?id=2587](https://ext.dcloud.net.cn/plugin?id=2587) | ||||||
|  | 7. 云端一体垂直布局,无图模式,主标题+副标题:[https://ext.dcloud.net.cn/plugin?id=2588](https://ext.dcloud.net.cn/plugin?id=2588) | ||||||
|  |  | ||||||
|  | **商品列表类** | ||||||
|  |  | ||||||
|  | 1. 云端一体列表/宫格视图互切:[https://ext.dcloud.net.cn/plugin?id=2651](https://ext.dcloud.net.cn/plugin?id=2651) | ||||||
|  | 2. 云端一体列表(宫格模式):[https://ext.dcloud.net.cn/plugin?id=2671](https://ext.dcloud.net.cn/plugin?id=2671) | ||||||
|  | 3. 云端一体列表(列表模式):[https://ext.dcloud.net.cn/plugin?id=2672](https://ext.dcloud.net.cn/plugin?id=2672) | ||||||
|  |  | ||||||
|  | ## 组件示例 | ||||||
|  |  | ||||||
|  | 点击查看:[https://hellouniapp.dcloud.net.cn/pages/extUI/list/list](https://hellouniapp.dcloud.net.cn/pages/extUI/list/list) | ||||||
							
								
								
									
										8
									
								
								uni_modules/uni-scss/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,8 @@ | |||||||
|  | ## 1.0.3(2022-01-21) | ||||||
|  | - 优化 组件示例 | ||||||
|  | ## 1.0.2(2021-11-22) | ||||||
|  | - 修复 / 符号在 vue 不同版本兼容问题引起的报错问题 | ||||||
|  | ## 1.0.1(2021-11-22) | ||||||
|  | - 修复 vue3中scss语法兼容问题 | ||||||
|  | ## 1.0.0(2021-11-18) | ||||||
|  | - init | ||||||
							
								
								
									
										1
									
								
								uni_modules/uni-scss/index.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | |||||||
|  | @import './styles/index.scss'; | ||||||
							
								
								
									
										82
									
								
								uni_modules/uni-scss/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,82 @@ | |||||||
|  | { | ||||||
|  |   "id": "uni-scss", | ||||||
|  |   "displayName": "uni-scss 辅助样式", | ||||||
|  |   "version": "1.0.3", | ||||||
|  |   "description": "uni-sass是uni-ui提供的一套全局样式 ,通过一些简单的类名和sass变量,实现简单的页面布局操作,比如颜色、边距、圆角等。", | ||||||
|  |   "keywords": [ | ||||||
|  |     "uni-scss", | ||||||
|  |     "uni-ui", | ||||||
|  |     "辅助样式" | ||||||
|  | ], | ||||||
|  |   "repository": "https://github.com/dcloudio/uni-ui", | ||||||
|  |   "engines": { | ||||||
|  |     "HBuilderX": "^3.1.0" | ||||||
|  |   }, | ||||||
|  |   "dcloudext": { | ||||||
|  |     "category": [ | ||||||
|  |         "JS SDK", | ||||||
|  |         "通用 SDK" | ||||||
|  |     ], | ||||||
|  |     "sale": { | ||||||
|  |       "regular": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       }, | ||||||
|  |       "sourcecode": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "contact": { | ||||||
|  |       "qq": "" | ||||||
|  |     }, | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "无", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "dependencies": [], | ||||||
|  |     "encrypt": [], | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "u" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "n", | ||||||
|  |           "联盟": "n" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |             "vue2": "y", | ||||||
|  |             "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								uni_modules/uni-scss/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,4 @@ | |||||||
|  | `uni-sass` 是 `uni-ui`提供的一套全局样式 ,通过一些简单的类名和`sass`变量,实现简单的页面布局操作,比如颜色、边距、圆角等。 | ||||||
|  |  | ||||||
|  | ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-sass) | ||||||
|  | #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||||
							
								
								
									
										7
									
								
								uni_modules/uni-scss/styles/index.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | |||||||
|  | @import './setting/_variables.scss'; | ||||||
|  | @import './setting/_border.scss'; | ||||||
|  | @import './setting/_color.scss'; | ||||||
|  | @import './setting/_space.scss'; | ||||||
|  | @import './setting/_radius.scss'; | ||||||
|  | @import './setting/_text.scss'; | ||||||
|  | @import './setting/_styles.scss'; | ||||||
							
								
								
									
										3
									
								
								uni_modules/uni-scss/styles/setting/_border.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | |||||||
|  | .uni-border { | ||||||
|  | 	border: 1px $uni-border-1 solid; | ||||||
|  | } | ||||||
							
								
								
									
										66
									
								
								uni_modules/uni-scss/styles/setting/_color.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,66 @@ | |||||||
|  |  | ||||||
|  | // TODO 暂时不需要 class ,需要用户使用变量实现 ,如果使用类名其实并不推荐 | ||||||
|  | // @mixin get-styles($k,$c) { | ||||||
|  | // 	@if $k == size or $k == weight{ | ||||||
|  | // 		font-#{$k}:#{$c} | ||||||
|  | // 	}@else{ | ||||||
|  | // 		#{$k}:#{$c} | ||||||
|  | // 	} | ||||||
|  | // } | ||||||
|  | $uni-ui-color:( | ||||||
|  | 	// 主色 | ||||||
|  | 	primary: $uni-primary, | ||||||
|  | 	primary-disable: $uni-primary-disable, | ||||||
|  | 	primary-light: $uni-primary-light, | ||||||
|  | 	// 辅助色 | ||||||
|  | 	success: $uni-success, | ||||||
|  | 	success-disable: $uni-success-disable, | ||||||
|  | 	success-light: $uni-success-light, | ||||||
|  | 	warning: $uni-warning, | ||||||
|  | 	warning-disable: $uni-warning-disable, | ||||||
|  | 	warning-light: $uni-warning-light, | ||||||
|  | 	error: $uni-error, | ||||||
|  | 	error-disable: $uni-error-disable, | ||||||
|  | 	error-light: $uni-error-light, | ||||||
|  | 	info: $uni-info, | ||||||
|  | 	info-disable: $uni-info-disable, | ||||||
|  | 	info-light: $uni-info-light, | ||||||
|  | 	// 中性色 | ||||||
|  | 	main-color: $uni-main-color, | ||||||
|  | 	base-color: $uni-base-color, | ||||||
|  | 	secondary-color: $uni-secondary-color, | ||||||
|  | 	extra-color: $uni-extra-color, | ||||||
|  | 	// 背景色 | ||||||
|  | 	bg-color: $uni-bg-color, | ||||||
|  | 	// 边框颜色 | ||||||
|  | 	border-1: $uni-border-1, | ||||||
|  | 	border-2: $uni-border-2, | ||||||
|  | 	border-3: $uni-border-3, | ||||||
|  | 	border-4: $uni-border-4, | ||||||
|  | 	// 黑色 | ||||||
|  | 	black:$uni-black, | ||||||
|  | 	// 白色 | ||||||
|  | 	white:$uni-white, | ||||||
|  | 	// 透明 | ||||||
|  | 	transparent:$uni-transparent | ||||||
|  | ) !default; | ||||||
|  | @each $key, $child in $uni-ui-color { | ||||||
|  | 	.uni-#{"" + $key} { | ||||||
|  | 		color: $child; | ||||||
|  | 	} | ||||||
|  | 	.uni-#{"" + $key}-bg { | ||||||
|  | 		background-color: $child; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | .uni-shadow-sm { | ||||||
|  | 	box-shadow: $uni-shadow-sm; | ||||||
|  | } | ||||||
|  | .uni-shadow-base { | ||||||
|  | 	box-shadow: $uni-shadow-base; | ||||||
|  | } | ||||||
|  | .uni-shadow-lg { | ||||||
|  | 	box-shadow: $uni-shadow-lg; | ||||||
|  | } | ||||||
|  | .uni-mask { | ||||||
|  | 	background-color:$uni-mask; | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								uni_modules/uni-scss/styles/setting/_radius.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,55 @@ | |||||||
|  | @mixin radius($r,$d:null ,$important: false){ | ||||||
|  |   $radius-value:map-get($uni-radius, $r) if($important, !important, null); | ||||||
|  |   // Key exists within the $uni-radius variable | ||||||
|  |   @if (map-has-key($uni-radius, $r) and  $d){ | ||||||
|  | 		@if $d == t { | ||||||
|  | 				border-top-left-radius:$radius-value; | ||||||
|  | 				border-top-right-radius:$radius-value; | ||||||
|  | 		}@else if $d == r { | ||||||
|  | 				border-top-right-radius:$radius-value; | ||||||
|  | 				border-bottom-right-radius:$radius-value; | ||||||
|  | 		}@else if $d == b { | ||||||
|  | 				border-bottom-left-radius:$radius-value; | ||||||
|  | 				border-bottom-right-radius:$radius-value; | ||||||
|  | 		}@else if $d == l { | ||||||
|  | 				border-top-left-radius:$radius-value; | ||||||
|  | 				border-bottom-left-radius:$radius-value; | ||||||
|  | 		}@else if $d == tl { | ||||||
|  | 				border-top-left-radius:$radius-value; | ||||||
|  | 		}@else if $d == tr { | ||||||
|  | 				border-top-right-radius:$radius-value; | ||||||
|  | 		}@else if $d == br { | ||||||
|  | 				border-bottom-right-radius:$radius-value; | ||||||
|  | 		}@else if $d == bl { | ||||||
|  | 				border-bottom-left-radius:$radius-value; | ||||||
|  | 		} | ||||||
|  |   }@else{ | ||||||
|  | 		border-radius:$radius-value; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @each $key, $child in $uni-radius { | ||||||
|  | 	@if($key){ | ||||||
|  | 		.uni-radius-#{"" + $key} { | ||||||
|  | 				@include radius($key) | ||||||
|  | 		} | ||||||
|  | 	}@else{ | ||||||
|  | 		.uni-radius { | ||||||
|  | 				@include radius($key) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @each $direction in t, r, b, l,tl, tr, br, bl { | ||||||
|  | 	@each $key, $child in $uni-radius { | ||||||
|  | 		@if($key){ | ||||||
|  | 			.uni-radius-#{"" + $direction}-#{"" + $key} { | ||||||
|  | 				@include radius($key,$direction,false) | ||||||
|  | 			} | ||||||
|  | 		}@else{ | ||||||
|  | 			.uni-radius-#{$direction} { | ||||||
|  | 				@include radius($key,$direction,false) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										56
									
								
								uni_modules/uni-scss/styles/setting/_space.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,56 @@ | |||||||
|  |  | ||||||
|  | @mixin fn($space,$direction,$size,$n) { | ||||||
|  | 	@if $n { | ||||||
|  | 		#{$space}-#{$direction}: #{$size*$uni-space-root}px | ||||||
|  | 	} @else { | ||||||
|  | 		 #{$space}-#{$direction}: #{-$size*$uni-space-root}px | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | @mixin get-styles($direction,$i,$space,$n){ | ||||||
|  | 	@if $direction == t { | ||||||
|  | 		@include fn($space, top,$i,$n); | ||||||
|  | 	}  | ||||||
|  | 	@if $direction == r { | ||||||
|  | 		@include fn($space, right,$i,$n); | ||||||
|  | 	}  | ||||||
|  | 	@if $direction == b { | ||||||
|  | 		@include fn($space, bottom,$i,$n); | ||||||
|  | 	}  | ||||||
|  | 	@if $direction == l { | ||||||
|  | 	 @include fn($space, left,$i,$n); | ||||||
|  | 	}  | ||||||
|  | 	@if $direction == x { | ||||||
|  | 		@include fn($space, left,$i,$n); | ||||||
|  | 		@include fn($space, right,$i,$n); | ||||||
|  | 	}  | ||||||
|  | 	@if $direction == y { | ||||||
|  | 		@include fn($space, top,$i,$n); | ||||||
|  | 		@include fn($space, bottom,$i,$n); | ||||||
|  | 	}  | ||||||
|  | 	@if $direction == a { | ||||||
|  | 		@if $n { | ||||||
|  | 			#{$space}:#{$i*$uni-space-root}px; | ||||||
|  | 		} @else { | ||||||
|  | 			#{$space}:#{-$i*$uni-space-root}px; | ||||||
|  | 		} | ||||||
|  | 	}  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @each $orientation in m,p { | ||||||
|  | 	$space: margin; | ||||||
|  | 	@if $orientation == m { | ||||||
|  | 		$space: margin; | ||||||
|  | 	} @else { | ||||||
|  | 		$space: padding; | ||||||
|  | 	} | ||||||
|  | 	@for $i from 0 through 16 { | ||||||
|  | 		@each $direction in t, r, b, l, x, y, a { | ||||||
|  | 			.uni-#{$orientation}#{$direction}-#{$i} {  | ||||||
|  | 				@include  get-styles($direction,$i,$space,true); | ||||||
|  | 			}  | ||||||
|  | 			.uni-#{$orientation}#{$direction}-n#{$i} {  | ||||||
|  | 				@include  get-styles($direction,$i,$space,false); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										167
									
								
								uni_modules/uni-scss/styles/setting/_styles.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,167 @@ | |||||||
|  | /* #ifndef APP-NVUE */ | ||||||
|  |  | ||||||
|  | $-color-white:#fff; | ||||||
|  | $-color-black:#000; | ||||||
|  | @mixin base-style($color) { | ||||||
|  | 	color: #fff; | ||||||
|  | 	background-color: $color; | ||||||
|  | 	border-color: mix($-color-black, $color, 8%); | ||||||
|  | 	&:not([hover-class]):active { | ||||||
|  | 		background: mix($-color-black, $color, 10%); | ||||||
|  | 		border-color: mix($-color-black, $color, 20%); | ||||||
|  | 		color: $-color-white; | ||||||
|  | 		outline: none; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | @mixin is-color($color) { | ||||||
|  | 	@include base-style($color); | ||||||
|  | 	&[loading] { | ||||||
|  | 		@include base-style($color); | ||||||
|  | 		&::before { | ||||||
|  | 			margin-right:5px; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	&[disabled] { | ||||||
|  | 	  &, | ||||||
|  | 		&[loading], | ||||||
|  | 	  &:not([hover-class]):active { | ||||||
|  | 	    color: $-color-white; | ||||||
|  | 			border-color: mix(darken($color,10%), $-color-white); | ||||||
|  | 	    background-color: mix($color, $-color-white); | ||||||
|  | 	  } | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
|  | @mixin base-plain-style($color) { | ||||||
|  | 	color:$color; | ||||||
|  | 	background-color: mix($-color-white, $color, 90%); | ||||||
|  | 	border-color: mix($-color-white, $color, 70%); | ||||||
|  | 	&:not([hover-class]):active { | ||||||
|  | 	  background: mix($-color-white, $color, 80%); | ||||||
|  | 	  color: $color; | ||||||
|  | 	  outline: none; | ||||||
|  | 		border-color: mix($-color-white, $color, 50%); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | @mixin is-plain($color){ | ||||||
|  | 	&[plain] { | ||||||
|  | 		@include base-plain-style($color); | ||||||
|  | 		&[loading] { | ||||||
|  | 			@include base-plain-style($color); | ||||||
|  | 			&::before { | ||||||
|  | 				margin-right:5px; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		&[disabled] { | ||||||
|  | 		  &, | ||||||
|  | 		  &:active { | ||||||
|  | 		    color: mix($-color-white, $color, 40%); | ||||||
|  | 		    background-color: mix($-color-white, $color, 90%); | ||||||
|  | 				border-color: mix($-color-white, $color, 80%); | ||||||
|  | 		  } | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .uni-btn { | ||||||
|  | 	margin: 5px; | ||||||
|  | 	color: #393939; | ||||||
|  | 	border:1px solid #ccc; | ||||||
|  | 	font-size: 16px; | ||||||
|  | 	font-weight: 200; | ||||||
|  | 	background-color: #F9F9F9; | ||||||
|  | 	// TODO 暂时处理边框隐藏一边的问题 | ||||||
|  | 	overflow: visible; | ||||||
|  | 	&::after{ | ||||||
|  | 		border: none; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	&:not([type]),&[type=default] { | ||||||
|  | 		color: #999; | ||||||
|  | 		&[loading] { | ||||||
|  | 			background: none; | ||||||
|  | 			&::before { | ||||||
|  | 				margin-right:5px; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 		&[disabled]{ | ||||||
|  | 			color: mix($-color-white, #999, 60%); | ||||||
|  | 		  &, | ||||||
|  | 			&[loading], | ||||||
|  | 		  &:active { | ||||||
|  | 				color: mix($-color-white, #999, 60%); | ||||||
|  | 		    background-color: mix($-color-white,$-color-black , 98%); | ||||||
|  | 				border-color: mix($-color-white,  #999, 85%); | ||||||
|  | 		  } | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		&[plain] { | ||||||
|  | 			color: #999; | ||||||
|  | 			background: none; | ||||||
|  | 			border-color: $uni-border-1; | ||||||
|  | 			&:not([hover-class]):active { | ||||||
|  | 				background: none; | ||||||
|  | 			  color: mix($-color-white, $-color-black, 80%); | ||||||
|  | 				border-color: mix($-color-white, $-color-black, 90%); | ||||||
|  | 			  outline: none; | ||||||
|  | 			} | ||||||
|  | 			&[disabled]{ | ||||||
|  | 			  &, | ||||||
|  | 				&[loading], | ||||||
|  | 			  &:active { | ||||||
|  | 			    background: none; | ||||||
|  | 					color: mix($-color-white, #999, 60%); | ||||||
|  | 					border-color: mix($-color-white,  #999, 85%); | ||||||
|  | 			  } | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	&:not([hover-class]):active { | ||||||
|  | 	  color: mix($-color-white, $-color-black, 50%); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	&[size=mini] { | ||||||
|  | 		font-size: 16px; | ||||||
|  | 		font-weight: 200; | ||||||
|  | 		border-radius: 8px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	&.uni-btn-small { | ||||||
|  | 		font-size: 14px; | ||||||
|  | 	} | ||||||
|  | 	&.uni-btn-mini { | ||||||
|  | 		font-size: 12px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	&.uni-btn-radius { | ||||||
|  | 		border-radius: 999px; | ||||||
|  | 	} | ||||||
|  | 	&[type=primary] { | ||||||
|  | 		@include is-color($uni-primary); | ||||||
|  | 		@include is-plain($uni-primary) | ||||||
|  | 	} | ||||||
|  | 	&[type=success] { | ||||||
|  | 		@include is-color($uni-success); | ||||||
|  | 		@include is-plain($uni-success) | ||||||
|  | 	} | ||||||
|  | 	&[type=error] { | ||||||
|  | 		@include is-color($uni-error); | ||||||
|  | 		@include is-plain($uni-error) | ||||||
|  | 	} | ||||||
|  | 	&[type=warning] { | ||||||
|  | 		@include is-color($uni-warning); | ||||||
|  | 		@include is-plain($uni-warning) | ||||||
|  | 	} | ||||||
|  | 	&[type=info] { | ||||||
|  | 		@include is-color($uni-info); | ||||||
|  | 		@include is-plain($uni-info) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | /* #endif */ | ||||||
							
								
								
									
										24
									
								
								uni_modules/uni-scss/styles/setting/_text.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,24 @@ | |||||||
|  | @mixin get-styles($k,$c) { | ||||||
|  | 	@if $k == size or $k == weight{ | ||||||
|  | 		font-#{$k}:#{$c} | ||||||
|  | 	}@else{ | ||||||
|  | 		#{$k}:#{$c} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @each $key, $child in $uni-headings { | ||||||
|  | 	/* #ifndef APP-NVUE */ | ||||||
|  | 	.uni-#{$key} { | ||||||
|  | 		@each $k, $c in $child { | ||||||
|  | 			@include get-styles($k,$c) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	/* #endif */ | ||||||
|  | 	/* #ifdef APP-NVUE */ | ||||||
|  | 	.container .uni-#{$key} { | ||||||
|  | 		@each $k, $c in $child { | ||||||
|  | 			@include get-styles($k,$c) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	/* #endif */ | ||||||
|  | } | ||||||
							
								
								
									
										146
									
								
								uni_modules/uni-scss/styles/setting/_variables.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,146 @@ | |||||||
|  | // @use "sass:math"; | ||||||
|  | @import  '../tools/functions.scss'; | ||||||
|  | // 间距基础倍数 | ||||||
|  | $uni-space-root: 2 !default; | ||||||
|  | // 边框半径默认值 | ||||||
|  | $uni-radius-root:5px !default; | ||||||
|  | $uni-radius: () !default; | ||||||
|  | // 边框半径断点 | ||||||
|  | $uni-radius: map-deep-merge( | ||||||
|  |   ( | ||||||
|  |     0: 0, | ||||||
|  | 		// TODO 当前版本暂时不支持 sm 属性 | ||||||
|  |     // 'sm': math.div($uni-radius-root, 2), | ||||||
|  |     null: $uni-radius-root, | ||||||
|  |     'lg': $uni-radius-root * 2, | ||||||
|  |     'xl': $uni-radius-root * 6, | ||||||
|  |     'pill': 9999px, | ||||||
|  |     'circle': 50% | ||||||
|  |   ), | ||||||
|  |   $uni-radius | ||||||
|  | ); | ||||||
|  | // 字体家族 | ||||||
|  | $body-font-family: 'Roboto', sans-serif !default; | ||||||
|  | // 文本 | ||||||
|  | $heading-font-family: $body-font-family !default; | ||||||
|  | $uni-headings: () !default; | ||||||
|  | $letterSpacing: -0.01562em; | ||||||
|  | $uni-headings: map-deep-merge( | ||||||
|  |   ( | ||||||
|  |     'h1': ( | ||||||
|  |       size: 32px, | ||||||
|  | 			weight: 300, | ||||||
|  | 			line-height: 50px, | ||||||
|  | 			// letter-spacing:-0.01562em | ||||||
|  |     ), | ||||||
|  |     'h2': ( | ||||||
|  |       size: 28px, | ||||||
|  |       weight: 300, | ||||||
|  |       line-height: 40px, | ||||||
|  |       // letter-spacing: -0.00833em | ||||||
|  |     ), | ||||||
|  |     'h3': ( | ||||||
|  |       size: 24px, | ||||||
|  |       weight: 400, | ||||||
|  |       line-height: 32px, | ||||||
|  |       // letter-spacing: normal | ||||||
|  |     ), | ||||||
|  |     'h4': ( | ||||||
|  |       size: 20px, | ||||||
|  |       weight: 400, | ||||||
|  |       line-height: 30px, | ||||||
|  |       // letter-spacing: 0.00735em | ||||||
|  |     ), | ||||||
|  |     'h5': ( | ||||||
|  |       size: 16px, | ||||||
|  |       weight: 400, | ||||||
|  |       line-height: 24px, | ||||||
|  |       // letter-spacing: normal | ||||||
|  |     ), | ||||||
|  |     'h6': ( | ||||||
|  |       size: 14px, | ||||||
|  |       weight: 500, | ||||||
|  |       line-height: 18px, | ||||||
|  |       // letter-spacing: 0.0125em | ||||||
|  |     ), | ||||||
|  |     'subtitle': ( | ||||||
|  |       size: 12px, | ||||||
|  |       weight: 400, | ||||||
|  |       line-height: 20px, | ||||||
|  |       // letter-spacing: 0.00937em | ||||||
|  |     ), | ||||||
|  |     'body': ( | ||||||
|  |       font-size: 14px, | ||||||
|  | 			font-weight: 400, | ||||||
|  | 			line-height: 22px, | ||||||
|  | 			// letter-spacing: 0.03125em | ||||||
|  |     ), | ||||||
|  |     'caption': ( | ||||||
|  |       'size': 12px, | ||||||
|  |       'weight': 400, | ||||||
|  |       'line-height': 20px, | ||||||
|  |       // 'letter-spacing': 0.03333em, | ||||||
|  |       // 'text-transform': false | ||||||
|  |     ) | ||||||
|  |   ), | ||||||
|  |   $uni-headings | ||||||
|  | ); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // 主色 | ||||||
|  | $uni-primary: #2979ff !default; | ||||||
|  | $uni-primary-disable:lighten($uni-primary,20%) !default; | ||||||
|  | $uni-primary-light: lighten($uni-primary,25%) !default; | ||||||
|  |  | ||||||
|  | // 辅助色 | ||||||
|  | // 除了主色外的场景色,需要在不同的场景中使用(例如危险色表示危险的操作)。 | ||||||
|  | $uni-success: #18bc37 !default; | ||||||
|  | $uni-success-disable:lighten($uni-success,20%) !default; | ||||||
|  | $uni-success-light: lighten($uni-success,25%) !default; | ||||||
|  |  | ||||||
|  | $uni-warning: #f3a73f !default; | ||||||
|  | $uni-warning-disable:lighten($uni-warning,20%) !default; | ||||||
|  | $uni-warning-light: lighten($uni-warning,25%) !default; | ||||||
|  |  | ||||||
|  | $uni-error: #e43d33 !default; | ||||||
|  | $uni-error-disable:lighten($uni-error,20%) !default; | ||||||
|  | $uni-error-light: lighten($uni-error,25%) !default; | ||||||
|  |  | ||||||
|  | $uni-info: #8f939c !default; | ||||||
|  | $uni-info-disable:lighten($uni-info,20%) !default; | ||||||
|  | $uni-info-light: lighten($uni-info,25%) !default; | ||||||
|  |  | ||||||
|  | // 中性色 | ||||||
|  | // 中性色用于文本、背景和边框颜色。通过运用不同的中性色,来表现层次结构。 | ||||||
|  | $uni-main-color: #3a3a3a !default; 			// 主要文字 | ||||||
|  | $uni-base-color: #6a6a6a !default;			// 常规文字 | ||||||
|  | $uni-secondary-color: #909399 !default;	// 次要文字 | ||||||
|  | $uni-extra-color: #c7c7c7 !default;			// 辅助说明 | ||||||
|  |  | ||||||
|  | // 边框颜色 | ||||||
|  | $uni-border-1: #F0F0F0 !default; | ||||||
|  | $uni-border-2: #EDEDED !default; | ||||||
|  | $uni-border-3: #DCDCDC !default; | ||||||
|  | $uni-border-4: #B9B9B9 !default; | ||||||
|  |  | ||||||
|  | // 常规色 | ||||||
|  | $uni-black: #000000 !default; | ||||||
|  | $uni-white: #ffffff !default; | ||||||
|  | $uni-transparent: rgba($color: #000000, $alpha: 0) !default; | ||||||
|  |  | ||||||
|  | // 背景色 | ||||||
|  | $uni-bg-color: #f7f7f7 !default; | ||||||
|  |  | ||||||
|  | /* 水平间距 */ | ||||||
|  | $uni-spacing-sm: 8px !default; | ||||||
|  | $uni-spacing-base: 15px !default; | ||||||
|  | $uni-spacing-lg: 30px !default; | ||||||
|  |  | ||||||
|  | // 阴影 | ||||||
|  | $uni-shadow-sm:0 0 5px rgba($color: #d8d8d8, $alpha: 0.5) !default; | ||||||
|  | $uni-shadow-base:0 1px 8px 1px rgba($color: #a5a5a5, $alpha: 0.2) !default; | ||||||
|  | $uni-shadow-lg:0px 1px 10px 2px rgba($color: #a5a4a4, $alpha: 0.5) !default; | ||||||
|  |  | ||||||
|  | // 蒙版 | ||||||
|  | $uni-mask: rgba($color: #000000, $alpha: 0.4) !default; | ||||||
							
								
								
									
										19
									
								
								uni_modules/uni-scss/styles/tools/functions.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,19 @@ | |||||||
|  | // 合并 map | ||||||
|  | @function map-deep-merge($parent-map, $child-map){ | ||||||
|  | 	$result: $parent-map; | ||||||
|  | 	@each $key, $child in $child-map { | ||||||
|  | 		$parent-has-key: map-has-key($result, $key); | ||||||
|  | 		$parent-value: map-get($result, $key); | ||||||
|  | 		$parent-type: type-of($parent-value); | ||||||
|  | 		$child-type: type-of($child); | ||||||
|  | 		$parent-is-map: $parent-type == map; | ||||||
|  | 		$child-is-map: $child-type == map; | ||||||
|  | 			 | ||||||
|  | 		@if (not $parent-has-key) or ($parent-type != $child-type) or (not ($parent-is-map and $child-is-map)){ | ||||||
|  | 			$result: map-merge($result, ( $key: $child )); | ||||||
|  | 		}@else { | ||||||
|  | 			$result: map-merge($result, ( $key: map-deep-merge($parent-value, $child) )); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	@return $result; | ||||||
|  | }; | ||||||
							
								
								
									
										31
									
								
								uni_modules/uni-scss/theme.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,31 @@ | |||||||
|  | // 间距基础倍数 | ||||||
|  | $uni-space-root: 2; | ||||||
|  | // 边框半径默认值 | ||||||
|  | $uni-radius-root:5px; | ||||||
|  | // 主色 | ||||||
|  | $uni-primary: #2979ff; | ||||||
|  | // 辅助色 | ||||||
|  | $uni-success: #4cd964; | ||||||
|  | // 警告色 | ||||||
|  | $uni-warning: #f0ad4e; | ||||||
|  | // 错误色 | ||||||
|  | $uni-error: #dd524d; | ||||||
|  | // 描述色 | ||||||
|  | $uni-info: #909399; | ||||||
|  | // 中性色 | ||||||
|  | $uni-main-color: #303133; | ||||||
|  | $uni-base-color: #606266; | ||||||
|  | $uni-secondary-color: #909399; | ||||||
|  | $uni-extra-color: #C0C4CC; | ||||||
|  | // 背景色 | ||||||
|  | $uni-bg-color: #f5f5f5; | ||||||
|  | // 边框颜色 | ||||||
|  | $uni-border-1: #DCDFE6; | ||||||
|  | $uni-border-2: #E4E7ED; | ||||||
|  | $uni-border-3: #EBEEF5; | ||||||
|  | $uni-border-4: #F2F6FC; | ||||||
|  |  | ||||||
|  | // 常规色 | ||||||
|  | $uni-black: #000000; | ||||||
|  | $uni-white: #ffffff; | ||||||
|  | $uni-transparent: rgba($color: #000000, $alpha: 0); | ||||||
							
								
								
									
										62
									
								
								uni_modules/uni-scss/variables.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,62 @@ | |||||||
|  | @import './styles/setting/_variables.scss'; | ||||||
|  | // 间距基础倍数 | ||||||
|  | $uni-space-root: 2; | ||||||
|  | // 边框半径默认值 | ||||||
|  | $uni-radius-root:5px; | ||||||
|  |  | ||||||
|  | // 主色 | ||||||
|  | $uni-primary: #2979ff; | ||||||
|  | $uni-primary-disable:mix(#fff,$uni-primary,50%); | ||||||
|  | $uni-primary-light: mix(#fff,$uni-primary,80%); | ||||||
|  |  | ||||||
|  | // 辅助色 | ||||||
|  | // 除了主色外的场景色,需要在不同的场景中使用(例如危险色表示危险的操作)。 | ||||||
|  | $uni-success: #18bc37; | ||||||
|  | $uni-success-disable:mix(#fff,$uni-success,50%); | ||||||
|  | $uni-success-light: mix(#fff,$uni-success,80%); | ||||||
|  |  | ||||||
|  | $uni-warning: #f3a73f; | ||||||
|  | $uni-warning-disable:mix(#fff,$uni-warning,50%); | ||||||
|  | $uni-warning-light: mix(#fff,$uni-warning,80%); | ||||||
|  |  | ||||||
|  | $uni-error: #e43d33; | ||||||
|  | $uni-error-disable:mix(#fff,$uni-error,50%); | ||||||
|  | $uni-error-light: mix(#fff,$uni-error,80%); | ||||||
|  |  | ||||||
|  | $uni-info: #8f939c; | ||||||
|  | $uni-info-disable:mix(#fff,$uni-info,50%); | ||||||
|  | $uni-info-light: mix(#fff,$uni-info,80%); | ||||||
|  |  | ||||||
|  | // 中性色 | ||||||
|  | // 中性色用于文本、背景和边框颜色。通过运用不同的中性色,来表现层次结构。 | ||||||
|  | $uni-main-color: #3a3a3a; 			// 主要文字 | ||||||
|  | $uni-base-color: #6a6a6a;			// 常规文字 | ||||||
|  | $uni-secondary-color: #909399;	// 次要文字 | ||||||
|  | $uni-extra-color: #c7c7c7;			// 辅助说明 | ||||||
|  |  | ||||||
|  | // 边框颜色 | ||||||
|  | $uni-border-1: #F0F0F0; | ||||||
|  | $uni-border-2: #EDEDED; | ||||||
|  | $uni-border-3: #DCDCDC; | ||||||
|  | $uni-border-4: #B9B9B9; | ||||||
|  |  | ||||||
|  | // 常规色 | ||||||
|  | $uni-black: #000000; | ||||||
|  | $uni-white: #ffffff; | ||||||
|  | $uni-transparent: rgba($color: #000000, $alpha: 0); | ||||||
|  |  | ||||||
|  | // 背景色 | ||||||
|  | $uni-bg-color: #f7f7f7; | ||||||
|  |  | ||||||
|  | /* 水平间距 */ | ||||||
|  | $uni-spacing-sm: 8px; | ||||||
|  | $uni-spacing-base: 15px; | ||||||
|  | $uni-spacing-lg: 30px; | ||||||
|  |  | ||||||
|  | // 阴影 | ||||||
|  | $uni-shadow-sm:0 0 5px rgba($color: #d8d8d8, $alpha: 0.5); | ||||||
|  | $uni-shadow-base:0 1px 8px 1px rgba($color: #a5a5a5, $alpha: 0.2); | ||||||
|  | $uni-shadow-lg:0px 1px 10px 2px rgba($color: #a5a4a4, $alpha: 0.5); | ||||||
|  |  | ||||||
|  | // 蒙版 | ||||||
|  | $uni-mask: rgba($color: #000000, $alpha: 0.4); | ||||||
							
								
								
									
										33
									
								
								uni_modules/uni-search-bar/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,33 @@ | |||||||
|  | ## 1.2.3(2022-05-24) | ||||||
|  | - 新增 readonly 属性,组件只读 | ||||||
|  | ## 1.2.2(2022-05-06) | ||||||
|  | - 修复  vue3 input 事件不生效的bug | ||||||
|  | ## 1.2.1(2022-05-06) | ||||||
|  | - 修复 多余代码导致的bug | ||||||
|  | ## 1.2.0(2021-11-19) | ||||||
|  | - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||||
|  | - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-search-bar](https://uniapp.dcloud.io/component/uniui/uni-search-bar) | ||||||
|  | ## 1.1.2(2021-08-30) | ||||||
|  | - 修复 value 属性与 modelValue 属性不兼容的Bug | ||||||
|  | ## 1.1.1(2021-08-24) | ||||||
|  | - 新增 支持国际化 | ||||||
|  | ## 1.1.0(2021-07-30) | ||||||
|  | - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||||
|  | ## 1.0.9(2021-05-12) | ||||||
|  | - 新增 项目示例地址 | ||||||
|  | ## 1.0.8(2021-04-21) | ||||||
|  | - 优化 添加依赖 uni-icons, 导入后自动下载依赖 | ||||||
|  | ## 1.0.7(2021-04-15) | ||||||
|  | - uni-ui 新增 uni-search-bar 的 focus 事件 | ||||||
|  |  | ||||||
|  | ## 1.0.6(2021-02-05) | ||||||
|  | - 优化 组件引用关系,通过uni_modules引用组件 | ||||||
|  |  | ||||||
|  | ## 1.0.5(2021-02-05) | ||||||
|  | - 调整为uni_modules目录规范 | ||||||
|  | - 新增 支持双向绑定 | ||||||
|  | - 更改 input 事件的返回值,e={value:Number} --> e=value | ||||||
|  | - 新增 支持图标插槽 | ||||||
|  | - 新增 支持 clear、blur 事件 | ||||||
|  | - 新增 支持 focus 属性 | ||||||
|  | - 去掉组件背景色 | ||||||
| @@ -0,0 +1,4 @@ | |||||||
|  | { | ||||||
|  | 	"uni-search-bar.cancel": "cancel", | ||||||
|  | 	"uni-search-bar.placeholder": "Search enter content" | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | import en from './en.json' | ||||||
|  | import zhHans from './zh-Hans.json' | ||||||
|  | import zhHant from './zh-Hant.json' | ||||||
|  | export default { | ||||||
|  | 	en, | ||||||
|  | 	'zh-Hans': zhHans, | ||||||
|  | 	'zh-Hant': zhHant | ||||||
|  | } | ||||||
| @@ -0,0 +1,4 @@ | |||||||
|  | { | ||||||
|  | 	"uni-search-bar.cancel": "cancel", | ||||||
|  | 	"uni-search-bar.placeholder": "请输入搜索内容" | ||||||
|  | } | ||||||
| @@ -0,0 +1,4 @@ | |||||||
|  | { | ||||||
|  | 	"uni-search-bar.cancel": "cancel", | ||||||
|  | 	"uni-search-bar.placeholder": "請輸入搜索內容" | ||||||
|  | } | ||||||
| @@ -0,0 +1,298 @@ | |||||||
|  | <template> | ||||||
|  | 	<view class="uni-searchbar"> | ||||||
|  | 		<view :style="{borderRadius:radius+'px',backgroundColor: bgColor}" class="uni-searchbar__box" | ||||||
|  | 			@click="searchClick"> | ||||||
|  | 			<view class="uni-searchbar__box-icon-search"> | ||||||
|  | 				<slot name="searchIcon"> | ||||||
|  | 					<uni-icons color="#c0c4cc" size="18" type="search" /> | ||||||
|  | 				</slot> | ||||||
|  | 			</view> | ||||||
|  | 			<input v-if="show || searchVal" :focus="showSync" :disabled="readonly" :placeholder="placeholderText" :maxlength="maxlength" | ||||||
|  | 				class="uni-searchbar__box-search-input" confirm-type="search" type="text" v-model="searchVal" | ||||||
|  | 				@confirm="confirm" @blur="blur" @focus="emitFocus" /> | ||||||
|  | 			<text v-else class="uni-searchbar__text-placeholder">{{ placeholder }}</text> | ||||||
|  | 			<view v-if="show && (clearButton==='always'||clearButton==='auto'&&searchVal!=='') &&!readonly" | ||||||
|  | 				class="uni-searchbar__box-icon-clear" @click="clear"> | ||||||
|  | 				<slot name="clearIcon"> | ||||||
|  | 					<uni-icons color="#c0c4cc" size="20" type="clear" /> | ||||||
|  | 				</slot> | ||||||
|  | 			</view> | ||||||
|  | 		</view> | ||||||
|  | 		<text @click="cancel" class="uni-searchbar__cancel" | ||||||
|  | 			v-if="cancelButton ==='always' || show && cancelButton ==='auto'">{{cancelTextI18n}}</text> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | 	import { | ||||||
|  | 		initVueI18n | ||||||
|  | 	} from '@dcloudio/uni-i18n' | ||||||
|  | 	import messages from './i18n/index.js' | ||||||
|  | 	const { | ||||||
|  | 		t | ||||||
|  | 	} = initVueI18n(messages) | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * SearchBar 搜索栏 | ||||||
|  | 	 * @description 搜索栏组件,通常用于搜索商品、文章等 | ||||||
|  | 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=866 | ||||||
|  | 	 * @property {Number} radius 搜索栏圆角 | ||||||
|  | 	 * @property {Number} maxlength 输入最大长度 | ||||||
|  | 	 * @property {String} placeholder 搜索栏Placeholder | ||||||
|  | 	 * @property {String} clearButton = [always|auto|none] 是否显示清除按钮 | ||||||
|  | 	 * 	@value always 一直显示 | ||||||
|  | 	 * 	@value auto 输入框不为空时显示 | ||||||
|  | 	 * 	@value none 一直不显示 | ||||||
|  | 	 * @property {String} cancelButton = [always|auto|none] 是否显示取消按钮 | ||||||
|  | 	 * 	@value always 一直显示 | ||||||
|  | 	 * 	@value auto 输入框不为空时显示 | ||||||
|  | 	 * 	@value none 一直不显示 | ||||||
|  | 	 * @property {String} cancelText 取消按钮的文字 | ||||||
|  | 	 * @property {String} bgColor 输入框背景颜色 | ||||||
|  | 	 * @property {Boolean} focus 是否自动聚焦 | ||||||
|  | 	 * @property {Boolean} readonly 组件只读,不能有任何操作,只做展示 | ||||||
|  | 	 * @event {Function} confirm uniSearchBar 的输入框 confirm 事件,返回参数为uniSearchBar的value,e={value:Number} | ||||||
|  | 	 * @event {Function} input uniSearchBar 的 value 改变时触发事件,返回参数为uniSearchBar的value,e=value | ||||||
|  | 	 * @event {Function} cancel 点击取消按钮时触发事件,返回参数为uniSearchBar的value,e={value:Number} | ||||||
|  | 	 * @event {Function} clear 点击清除按钮时触发事件,返回参数为uniSearchBar的value,e={value:Number} | ||||||
|  | 	 * @event {Function} blur input失去焦点时触发事件,返回参数为uniSearchBar的value,e={value:Number} | ||||||
|  | 	 */ | ||||||
|  |  | ||||||
|  | 	export default { | ||||||
|  | 		name: "UniSearchBar", | ||||||
|  | 		emits: ['input', 'update:modelValue', 'clear', 'cancel', 'confirm', 'blur', 'focus'], | ||||||
|  | 		props: { | ||||||
|  | 			placeholder: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: "" | ||||||
|  | 			}, | ||||||
|  | 			radius: { | ||||||
|  | 				type: [Number, String], | ||||||
|  | 				default: 5 | ||||||
|  | 			}, | ||||||
|  | 			clearButton: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: "auto" | ||||||
|  | 			}, | ||||||
|  | 			cancelButton: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: "auto" | ||||||
|  | 			}, | ||||||
|  | 			cancelText: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: '取消' | ||||||
|  | 			}, | ||||||
|  | 			bgColor: { | ||||||
|  | 				type: String, | ||||||
|  | 				default: "#F8F8F8" | ||||||
|  | 			}, | ||||||
|  | 			maxlength: { | ||||||
|  | 				type: [Number, String], | ||||||
|  | 				default: 100 | ||||||
|  | 			}, | ||||||
|  | 			value: { | ||||||
|  | 				type: [Number, String], | ||||||
|  | 				default: "" | ||||||
|  | 			}, | ||||||
|  | 			modelValue: { | ||||||
|  | 				type: [Number, String], | ||||||
|  | 				default: "" | ||||||
|  | 			}, | ||||||
|  | 			focus: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			}, | ||||||
|  | 			readonly: { | ||||||
|  | 				type: Boolean, | ||||||
|  | 				default: false | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				show: false, | ||||||
|  | 				showSync: false, | ||||||
|  | 				searchVal: '' | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		computed: { | ||||||
|  | 			cancelTextI18n() { | ||||||
|  | 				return this.cancelText || t("uni-search-bar.cancel") | ||||||
|  | 			}, | ||||||
|  | 			placeholderText() { | ||||||
|  | 				return this.placeholder || t("uni-search-bar.placeholder") | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		watch: { | ||||||
|  | 			// #ifndef VUE3 | ||||||
|  | 			value: { | ||||||
|  | 				immediate: true, | ||||||
|  | 				handler(newVal) { | ||||||
|  | 					this.searchVal = newVal | ||||||
|  | 					if (newVal) { | ||||||
|  | 						this.show = true | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			// #endif | ||||||
|  | 			// #ifdef VUE3 | ||||||
|  | 			modelValue: { | ||||||
|  | 				immediate: true, | ||||||
|  | 				handler(newVal) { | ||||||
|  | 					this.searchVal = newVal | ||||||
|  | 					if (newVal) { | ||||||
|  | 						this.show = true | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			// #endif | ||||||
|  | 			focus: { | ||||||
|  | 				immediate: true, | ||||||
|  | 				handler(newVal) { | ||||||
|  | 					if (newVal) { | ||||||
|  | 						if(this.readonly) return | ||||||
|  | 						this.show = true; | ||||||
|  | 						this.$nextTick(() => { | ||||||
|  | 							this.showSync = true | ||||||
|  | 						}) | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			searchVal(newVal, oldVal) { | ||||||
|  | 				this.$emit("input", newVal) | ||||||
|  | 				// #ifdef VUE3 | ||||||
|  | 				this.$emit("update:modelValue", newVal) | ||||||
|  | 				// #endif | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			searchClick() { | ||||||
|  | 				if(this.readonly) return | ||||||
|  | 				if (this.show) { | ||||||
|  | 					return | ||||||
|  | 				} | ||||||
|  | 				this.show = true; | ||||||
|  | 				this.$nextTick(() => { | ||||||
|  | 					this.showSync = true | ||||||
|  | 				}) | ||||||
|  | 			}, | ||||||
|  | 			clear() { | ||||||
|  | 				this.$emit("clear", { | ||||||
|  | 					value: this.searchVal | ||||||
|  | 				}) | ||||||
|  | 				this.searchVal = "" | ||||||
|  | 			}, | ||||||
|  | 			cancel() { | ||||||
|  | 				if(this.readonly) return | ||||||
|  | 				this.$emit("cancel", { | ||||||
|  | 					value: this.searchVal | ||||||
|  | 				}); | ||||||
|  | 				this.searchVal = "" | ||||||
|  | 				this.show = false | ||||||
|  | 				this.showSync = false | ||||||
|  | 				// #ifndef APP-PLUS | ||||||
|  | 				uni.hideKeyboard() | ||||||
|  | 				// #endif | ||||||
|  | 				// #ifdef APP-PLUS | ||||||
|  | 				plus.key.hideSoftKeybord() | ||||||
|  | 				// #endif | ||||||
|  | 			}, | ||||||
|  | 			confirm() { | ||||||
|  | 				// #ifndef APP-PLUS | ||||||
|  | 				uni.hideKeyboard(); | ||||||
|  | 				// #endif | ||||||
|  | 				// #ifdef APP-PLUS | ||||||
|  | 				plus.key.hideSoftKeybord() | ||||||
|  | 				// #endif | ||||||
|  | 				this.$emit("confirm", { | ||||||
|  | 					value: this.searchVal | ||||||
|  | 				}) | ||||||
|  | 			}, | ||||||
|  | 			blur() { | ||||||
|  | 				// #ifndef APP-PLUS | ||||||
|  | 				uni.hideKeyboard(); | ||||||
|  | 				// #endif | ||||||
|  | 				// #ifdef APP-PLUS | ||||||
|  | 				plus.key.hideSoftKeybord() | ||||||
|  | 				// #endif | ||||||
|  | 				this.$emit("blur", { | ||||||
|  | 					value: this.searchVal | ||||||
|  | 				}) | ||||||
|  | 			}, | ||||||
|  | 			emitFocus(e) { | ||||||
|  | 				this.$emit("focus", e.detail) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss"> | ||||||
|  | 	$uni-searchbar-height: 36px; | ||||||
|  |  | ||||||
|  | 	.uni-searchbar { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		position: relative; | ||||||
|  | 		padding: 10px; | ||||||
|  | 		// background-color: #fff; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-searchbar__box { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		box-sizing: border-box; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		position: relative; | ||||||
|  | 		flex: 1; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		align-items: center; | ||||||
|  | 		height: $uni-searchbar-height; | ||||||
|  | 		padding: 5px 8px 5px 0px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-searchbar__box-icon-search { | ||||||
|  | 		/* #ifndef APP-NVUE */ | ||||||
|  | 		display: flex; | ||||||
|  | 		/* #endif */ | ||||||
|  | 		flex-direction: row; | ||||||
|  | 		// width: 32px; | ||||||
|  | 		padding: 0 8px; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		align-items: center; | ||||||
|  | 		color: #B3B3B3; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-searchbar__box-search-input { | ||||||
|  | 		flex: 1; | ||||||
|  | 		font-size: 14px; | ||||||
|  | 		color: #333; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-searchbar__box-icon-clear { | ||||||
|  | 		align-items: center; | ||||||
|  | 		line-height: 24px; | ||||||
|  | 		padding-left: 8px; | ||||||
|  | 		/* #ifdef H5 */ | ||||||
|  | 		cursor: pointer; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-searchbar__text-placeholder { | ||||||
|  | 		font-size: 14px; | ||||||
|  | 		color: #B3B3B3; | ||||||
|  | 		margin-left: 5px; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	.uni-searchbar__cancel { | ||||||
|  | 		padding-left: 10px; | ||||||
|  | 		line-height: $uni-searchbar-height; | ||||||
|  | 		font-size: 14px; | ||||||
|  | 		color: #333333; | ||||||
|  | 		/* #ifdef H5 */ | ||||||
|  | 		cursor: pointer; | ||||||
|  | 		/* #endif */ | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
							
								
								
									
										89
									
								
								uni_modules/uni-search-bar/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,89 @@ | |||||||
|  | { | ||||||
|  |   "id": "uni-search-bar", | ||||||
|  |   "displayName": "uni-search-bar 搜索栏", | ||||||
|  |   "version": "1.2.3", | ||||||
|  |   "description": "搜索栏组件,通常用于搜索商品、文章等", | ||||||
|  |   "keywords": [ | ||||||
|  |     "uni-ui", | ||||||
|  |     "uniui", | ||||||
|  |     "搜索框", | ||||||
|  |     "搜索栏" | ||||||
|  | ], | ||||||
|  |   "repository": "https://github.com/dcloudio/uni-ui", | ||||||
|  |   "engines": { | ||||||
|  |     "HBuilderX": "" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "example": "../../temps/example_temps" | ||||||
|  |   }, | ||||||
|  |   "dcloudext": { | ||||||
|  |     "category": [ | ||||||
|  |       "前端组件", | ||||||
|  |       "通用组件" | ||||||
|  |     ], | ||||||
|  |     "sale": { | ||||||
|  |       "regular": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       }, | ||||||
|  |       "sourcecode": { | ||||||
|  |         "price": "0.00" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "contact": { | ||||||
|  |       "qq": "" | ||||||
|  |     }, | ||||||
|  |     "declaration": { | ||||||
|  |       "ads": "无", | ||||||
|  |       "data": "无", | ||||||
|  |       "permissions": "无" | ||||||
|  |     }, | ||||||
|  |     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui" | ||||||
|  |   }, | ||||||
|  |   "uni_modules": { | ||||||
|  |     "dependencies": [ | ||||||
|  | 			"uni-scss", | ||||||
|  | 			"uni-icons" | ||||||
|  | 		], | ||||||
|  |     "encrypt": [], | ||||||
|  |     "platforms": { | ||||||
|  |       "cloud": { | ||||||
|  |         "tcb": "y", | ||||||
|  |         "aliyun": "y" | ||||||
|  |       }, | ||||||
|  |       "client": { | ||||||
|  |         "App": { | ||||||
|  |           "app-vue": "y", | ||||||
|  |           "app-nvue": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-mobile": { | ||||||
|  |           "Safari": "y", | ||||||
|  |           "Android Browser": "y", | ||||||
|  |           "微信浏览器(Android)": "y", | ||||||
|  |           "QQ浏览器(Android)": "y" | ||||||
|  |         }, | ||||||
|  |         "H5-pc": { | ||||||
|  |           "Chrome": "y", | ||||||
|  |           "IE": "y", | ||||||
|  |           "Edge": "y", | ||||||
|  |           "Firefox": "y", | ||||||
|  |           "Safari": "y" | ||||||
|  |         }, | ||||||
|  |         "小程序": { | ||||||
|  |           "微信": "y", | ||||||
|  |           "阿里": "y", | ||||||
|  |           "百度": "y", | ||||||
|  |           "字节跳动": "y", | ||||||
|  |           "QQ": "y" | ||||||
|  |         }, | ||||||
|  |         "快应用": { | ||||||
|  |           "华为": "u", | ||||||
|  |           "联盟": "u" | ||||||
|  |         }, | ||||||
|  |         "Vue": { | ||||||
|  |             "vue2": "y", | ||||||
|  |             "vue3": "y" | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								uni_modules/uni-search-bar/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  | ## SearchBar 搜索栏 | ||||||
|  |  | ||||||
|  | > **组件名:uni-search-bar** | ||||||
|  | > 代码块: `uSearchBar` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 搜索栏组件 | ||||||
|  |  | ||||||
|  | ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-search-bar) | ||||||
|  | #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||||
|  |  | ||||||
|  |  | ||||||