注释
							
								
								
									
										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  | ||||
|  | ||||
|  | ||||