登录和绑定手机
This commit is contained in:
		
							parent
							
								
									eb468e35a3
								
							
						
					
					
						commit
						7f1410eba2
					
				| @ -50,7 +50,7 @@ export function getCodeImg() { | |||||||
| // 获取验证码
 | // 获取验证码
 | ||||||
| export function loginApp(data) { | export function loginApp(data) { | ||||||
|   return request({ |   return request({ | ||||||
|     'url': '/rescue/loginApp', |     'url': '/rescue/loginQx', | ||||||
|     headers: { |     headers: { | ||||||
|       isToken: false |       isToken: false | ||||||
|     }, |     }, | ||||||
|  | |||||||
| @ -144,6 +144,13 @@ | |||||||
| 			{ | 			{ | ||||||
| 				"navigationBarTitleText" : "" | 				"navigationBarTitleText" : "" | ||||||
| 			} | 			} | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"path" : "pages/login/bindPhoe", | ||||||
|  | 			"style" :  | ||||||
|  | 			{ | ||||||
|  | 				"navigationBarTitleText" : "" | ||||||
|  | 			} | ||||||
| 		} | 		} | ||||||
| 	], | 	], | ||||||
| 	"globalStyle": { | 	"globalStyle": { | ||||||
|  | |||||||
							
								
								
									
										217
									
								
								pages/login/bindPhoe.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										217
									
								
								pages/login/bindPhoe.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,217 @@ | |||||||
|  | <template> | ||||||
|  | 	<view class="container"> | ||||||
|  | 		<view class="title">绑定手机号</view> | ||||||
|  | 		<view class="phone formItem"> | ||||||
|  | 			<image style="width: 28rpx;height: 28rpx;" src="../../static/icons/order-icon2.png" mode="aspectFit"> | ||||||
|  | 			</image> | ||||||
|  | 			<input v-model="phone" placeholder="请输入手机号" class="formItemInput" type="text" /> | ||||||
|  | 		</view> | ||||||
|  | 		<view class="validaCode formItem"> | ||||||
|  | 			<uni-icons type="locked"></uni-icons> | ||||||
|  | 			<input v-model="validaCode" class="formItemInput" placeholder="请输入验证码" type="text" /> | ||||||
|  | 			<view :class="{ 'disabled': isButtonDisabled }" class="validaCodeBtn" @click="sendVerificationCode">{{buttonText}}</view> | ||||||
|  | 		</view> | ||||||
|  | 
 | ||||||
|  | 		<view class="submit" @click="bindPhone"> | ||||||
|  | 			绑定 | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | 	import { setToken } from '../../utils/auth'; | ||||||
|  | import request from '../../utils/request'; | ||||||
|  | 	export default { | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				phone: '15254781016', | ||||||
|  | 				validaCode: '', | ||||||
|  | 				countdownTime: 60, | ||||||
|  | 				isButtonDisabled: false, | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		computed: { | ||||||
|  | 			buttonText() { | ||||||
|  | 				if (this.isButtonDisabled) { | ||||||
|  | 					return `${this.countdownTime}s 后重新发送`; | ||||||
|  | 				} else { | ||||||
|  | 					return "获取验证码"; | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			sendVerificationCode() { | ||||||
|  | 				if (this.isButtonDisabled) { | ||||||
|  | 					return | ||||||
|  | 				} | ||||||
|  | 				let reg = /^((13[0-9])|(14[0-9])|(15[0-9])|(17[0-9])|(18[0-9]))\d{8}$/; | ||||||
|  | 				if (!reg.test(this.phone)) { | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						icon: 'none', | ||||||
|  | 						title: '请输入正确的11位手机号' | ||||||
|  | 					}) | ||||||
|  | 					this.phone = ''; | ||||||
|  | 					return false; | ||||||
|  | 				} | ||||||
|  | 				if (this.isButtonDisabled) { | ||||||
|  | 					return; // 如果按钮已禁用,则直接返回 | ||||||
|  | 				} | ||||||
|  | 				const data = { | ||||||
|  | 					phone: this.phone, | ||||||
|  | 				} | ||||||
|  | 				request({ | ||||||
|  | 					url: '/rescue/sendSmsQx', | ||||||
|  | 					method: 'get', | ||||||
|  | 					params: data, | ||||||
|  | 					headers: { | ||||||
|  | 						isToken: false, | ||||||
|  | 					}, | ||||||
|  | 					header: { | ||||||
|  | 						Authorization: 'Bearer ' + uni.getStorageSync('validaCodeToken') | ||||||
|  | 					} | ||||||
|  | 				}).then((res) => { | ||||||
|  | 					console.log('验证码', res); | ||||||
|  | 					if (res.code == 200) { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '验证码已发送 请注意查收', | ||||||
|  | 							icon: 'none' | ||||||
|  | 						}) | ||||||
|  | 					} else { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '网络不佳请稍后再试', | ||||||
|  | 							icon: 'none' | ||||||
|  | 						}) | ||||||
|  | 					} | ||||||
|  | 				}) | ||||||
|  | 				this.disableButton(); // 禁用按钮 | ||||||
|  | 				this.startCountdown(); // 启动倒计时 | ||||||
|  | 			}, | ||||||
|  | 			disableButton() { | ||||||
|  | 				this.isButtonDisabled = true; | ||||||
|  | 			}, | ||||||
|  | 			enableButton() { | ||||||
|  | 				this.isButtonDisabled = false; | ||||||
|  | 			}, | ||||||
|  | 			startCountdown() { | ||||||
|  | 				let countdown = setInterval(() => { | ||||||
|  | 					this.countdownTime--; | ||||||
|  | 					if (this.countdownTime === 0) { | ||||||
|  | 						clearInterval(countdown); | ||||||
|  | 						this.enableButton(); // 启用按钮 | ||||||
|  | 					} | ||||||
|  | 				}, 1000); | ||||||
|  | 			}, | ||||||
|  | 			bindPhone() { | ||||||
|  | 				let reg = /^((13[0-9])|(14[0-9])|(15[0-9])|(17[0-9])|(18[0-9]))\d{8}$/; | ||||||
|  | 				if (!reg.test(this.phone)) { | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						icon: 'none', | ||||||
|  | 						title: '请输入正确的11位手机号' | ||||||
|  | 					}) | ||||||
|  | 					this.phone = ''; | ||||||
|  | 					return false; | ||||||
|  | 				} | ||||||
|  | 				if (!this.validaCode) { | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						icon: 'none', | ||||||
|  | 						title: '请输入验证码' | ||||||
|  | 					}) | ||||||
|  | 					return false; | ||||||
|  | 				} | ||||||
|  | 				 | ||||||
|  | 				request({ | ||||||
|  | 					url: '/rescue/updateUserQx', | ||||||
|  | 					method: 'post', | ||||||
|  | 					data: { | ||||||
|  | 						phone: this.phone, | ||||||
|  | 						code: this.validaCode | ||||||
|  | 					}, | ||||||
|  | 					headers: { | ||||||
|  | 						isToken: false, | ||||||
|  | 					}, | ||||||
|  | 					header: { | ||||||
|  | 						Authorization: 'Bearer ' + uni.getStorageSync('validaCodeToken') | ||||||
|  | 					} | ||||||
|  | 				}).then(res => { | ||||||
|  | 					console.log('updateUserQx: ',res); | ||||||
|  | 					if (res.code == 200) { | ||||||
|  | 						setToken(uni.getStorageSync('validaCodeToken')) | ||||||
|  | 						uni.reLaunch({ | ||||||
|  | 						  url: '/pages/home/home' | ||||||
|  | 						}) | ||||||
|  | 					} else { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: res.msg, | ||||||
|  | 							icon: 'none' | ||||||
|  | 						}) | ||||||
|  | 					} | ||||||
|  | 				}) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style lang="less" scoped> | ||||||
|  | 	.container { | ||||||
|  | 		height: 100%; | ||||||
|  | 		display: flex; | ||||||
|  | 		flex-direction: column; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		row-gap: 40rpx; | ||||||
|  | 		background-color: #F5F5F5; | ||||||
|  | 
 | ||||||
|  | 		.title { | ||||||
|  | 			font-size: 40rpx; | ||||||
|  | 			font-weight: bold; | ||||||
|  | 			margin-bottom: 20rpx; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		.formItem { | ||||||
|  | 			box-sizing: border-box; | ||||||
|  | 			width: 680rpx; | ||||||
|  | 			height: 100rpx; | ||||||
|  | 			border-radius: 50rpx; | ||||||
|  | 			background-color: #fff; | ||||||
|  | 			padding: 0 30rpx; | ||||||
|  | 
 | ||||||
|  | 			display: flex; | ||||||
|  | 			align-items: center; | ||||||
|  | 			column-gap: 16rpx; | ||||||
|  | 
 | ||||||
|  | 			.formItemInput { | ||||||
|  | 				flex: 1; | ||||||
|  | 				width: 0; | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			.validaCodeBtn { | ||||||
|  | 				background-color: #1890ff; | ||||||
|  | 				color: #fff; | ||||||
|  | 				height: 60rpx; | ||||||
|  | 				border-radius: 30rpx; | ||||||
|  | 				padding: 0 30rpx; | ||||||
|  | 				font-size: 28rpx; | ||||||
|  | 
 | ||||||
|  | 				display: flex; | ||||||
|  | 				align-items: center; | ||||||
|  | 				justify-content: center; | ||||||
|  | 				 | ||||||
|  | 				&.disabled { | ||||||
|  | 					background-color: #1890ff99; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		.submit { | ||||||
|  | 			height: 100rpx; | ||||||
|  | 			border-radius: 50rpx; | ||||||
|  | 			width: 600rpx; | ||||||
|  | 			background-color: #1890ff; | ||||||
|  | 			color: #fff; | ||||||
|  | 
 | ||||||
|  | 			display: flex; | ||||||
|  | 			align-items: center; | ||||||
|  | 			justify-content: center; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
| @ -1,36 +1,62 @@ | |||||||
| <template> | <template> | ||||||
| 	<view class="content"> | 	<view class="content"> | ||||||
| 		<view class="top"> | 		<view class="top"> | ||||||
|  | 			<view class="touxiang"> | ||||||
|  | 				<image src="../../static/xinlogo.png" mode=""></image> | ||||||
|  | 			</view> | ||||||
| 			<view class="inputs"> | 			<view class="inputs"> | ||||||
| 				<input type="text" v-model="userName" placeholder="请输入用户名"> | 				<input type="text" v-model="userName" placeholder="请输入用户名"> | ||||||
| 			</view> | 			</view> | ||||||
| 			<view class="inputs"> | 			<view class="inputs"> | ||||||
| 				<input type="password" v-model="wrod" placeholder="请输入密码"> | 				<input type="password" v-model="wrod" placeholder="请输入密码"> | ||||||
| 			</view> | 			</view> | ||||||
|  | 			<view class="wjworb" @click="goforgot()"> | ||||||
|  | 				<view class="">忘记密码</view> | ||||||
|  | 			</view> | ||||||
| 		</view> | 		</view> | ||||||
| 
 |  | ||||||
| 		<view class="dl" @click="getlogin()"> | 		<view class="dl" @click="getlogin()"> | ||||||
| 			<text>登 录</text> | 			<text>登 录</text> | ||||||
| 		</view> | 		</view> | ||||||
|  | 		<!-- 	<view class="hging"> | ||||||
|  | 			<text>没有账号?</text> | ||||||
|  | 			<text style="color: #0078FF;" @click="goregister()">立即注册</text> | ||||||
|  | 		</view> --> | ||||||
|  | 		<view class="dbottom"> | ||||||
|  | 			<view class="quanzi" v-if="qindex == false " @click="qindex =! qindex"></view> | ||||||
|  | 			<view class="lanquanzi" v-if="qindex == true" @click="qindex =! qindex"> | ||||||
|  | 				<uni-icons type="checkmarkempty" color="#ffffff" size="14"></uni-icons> | ||||||
|  | 			</view> | ||||||
|  | 			<text>请仔细阅读</text> | ||||||
|  | 			<text class="lan">《用户协议》</text> | ||||||
|  | 			<text>和</text> | ||||||
|  | 			<text class="lan">《隐私政策》</text> | ||||||
|  | 		</view> | ||||||
| 	</view> | 	</view> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| 	import request from '../../utils/request'; | 	import request from '../../utils/request'; | ||||||
| import {setToken, setTenantId} from '../../utils/auth.js' |  | ||||||
| 	import { | 	import { | ||||||
|  | 		loginApp | ||||||
|  | 	} from '@/api/login.js'; | ||||||
|  | 	import { | ||||||
|  | 		setToken, | ||||||
|  | 		setTenantId | ||||||
|  | 	} from '@/utils/auth.js' | ||||||
|  | 	import { | ||||||
|  | 		login, | ||||||
|  | 		getInfo, | ||||||
| 		getTenantIdByWebsite | 		getTenantIdByWebsite | ||||||
| 	} from '@/api/login.js' | 	} from '@/api/login.js' | ||||||
| 	export default { | 	export default { | ||||||
| 		data() { | 		data() { | ||||||
| 			return { | 			return { | ||||||
| 				phoneNumber: "", | 				phoneNumber: "", | ||||||
|  | 				baseUrl: this.$baseUrl, | ||||||
| 				isButtonDisabled: false, | 				isButtonDisabled: false, | ||||||
| 				countdownTime: 60, | 				countdownTime: 60, | ||||||
|       qh:[ | 				qindex: false, | ||||||
|         {text:'密码登录'}, | 				sfindex: 'user', | ||||||
|         {text:'验证码登录'} |  | ||||||
|       ], |  | ||||||
| 				userName: '', | 				userName: '', | ||||||
| 				yzm: '', | 				yzm: '', | ||||||
| 				wrod: '', | 				wrod: '', | ||||||
| @ -38,15 +64,13 @@ export default{ | |||||||
| 				tenantCode: 'lanan' | 				tenantCode: 'lanan' | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
|   created() { |  | ||||||
|     // getTenantIdByWebsite(this.tenantCode).then(res => { |  | ||||||
|     //   const tenantId = res.data; |  | ||||||
|     //   if (tenantId && tenantId >= 0) { |  | ||||||
|     //     setTenantId(tenantId) |  | ||||||
|     //   } |  | ||||||
|     // }) |  | ||||||
|   }, |  | ||||||
| 		computed: { | 		computed: { | ||||||
|  | 			groupChange(n) { | ||||||
|  | 				console.log('groupChange', n); | ||||||
|  | 			}, | ||||||
|  | 			radioChange(n) { | ||||||
|  | 				console.log('radioChange', n); | ||||||
|  | 			}, | ||||||
| 			buttonText() { | 			buttonText() { | ||||||
| 				if (this.isButtonDisabled) { | 				if (this.isButtonDisabled) { | ||||||
| 					return `${this.countdownTime}s 后重新发送`; | 					return `${this.countdownTime}s 后重新发送`; | ||||||
| @ -55,9 +79,23 @@ export default{ | |||||||
| 				} | 				} | ||||||
| 			}, | 			}, | ||||||
| 		}, | 		}, | ||||||
|  | 		mounted() {}, | ||||||
| 		methods: { | 		methods: { | ||||||
|  | 
 | ||||||
|  | 			setidentity(text) { | ||||||
|  | 				this.sfindex = text | ||||||
|  | 
 | ||||||
|  | 			}, | ||||||
| 			//登录请求 | 			//登录请求 | ||||||
| 			getlogin() { | 			getlogin() { | ||||||
|  | 				if (this.qindex != true) { | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						icon: "none", | ||||||
|  | 						title: "请阅读并勾选用户协议", | ||||||
|  | 						duration: 2000 | ||||||
|  | 					}) | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
| 				if (this.userName == '') { | 				if (this.userName == '') { | ||||||
| 					uni.showToast({ | 					uni.showToast({ | ||||||
| 						title: '输入框不能为空!', | 						title: '输入框不能为空!', | ||||||
| @ -66,30 +104,131 @@ export default{ | |||||||
| 					return | 					return | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
|       let data ={ | 				uni.setStorageSync('identity', this.sfindex); | ||||||
|  | 
 | ||||||
|  | 				const loginFun = () => { | ||||||
|  | 					const data = { | ||||||
| 						username: this.userName, | 						username: this.userName, | ||||||
| 						password: this.wrod, | 						password: this.wrod, | ||||||
| 						type: 0 | 						type: 0 | ||||||
| 					} | 					} | ||||||
|       console.log('密码请求',data); | 					loginApp(data).then(res => { | ||||||
|       request({ | 						if (res.data.needMobile === "1") { | ||||||
|         url: '/rescue/loginQx', | 							uni.navigateTo({ | ||||||
|         method: 'post', | 								url: '/pages/login/bindPhoe' | ||||||
|         data: data |  | ||||||
|       }).then((res)=>{ |  | ||||||
|         console.log('密码请求',res); |  | ||||||
|         if(res.code == 200){ |  | ||||||
|           setToken(res.data.accessToken) |  | ||||||
| 
 |  | ||||||
|           uni.reLaunch({ |  | ||||||
|             url: '/pages/index/index' |  | ||||||
| 							}) | 							}) | ||||||
|  | 							uni.setStorageSync('validaCodeToken', res.data.accessToken) | ||||||
|  | 						} else { | ||||||
|  | 							setToken(res.data.accessToken) | ||||||
|  | 							uni.reLaunch({ | ||||||
|  | 								url: '/pages/home/home' | ||||||
|  | 							}) | ||||||
|  | 						} | ||||||
|  | 					}) | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
|  | 				getTenantIdByWebsite(this.tenantCode).then(res => { | ||||||
|  | 					if (res.code === 200 && res.data && res.data.length > 0) { | ||||||
|  | 						uni.showActionSheet({ | ||||||
|  | 							itemList: res.data.map(m => m.name), | ||||||
|  | 							success: ({ | ||||||
|  | 								tapIndex | ||||||
|  | 							}) => { | ||||||
|  | 								setTenantId(res.data[tapIndex].id) | ||||||
|  | 								loginFun() | ||||||
|  | 							} | ||||||
|  | 						}) | ||||||
|  | 					} else { | ||||||
|  | 						setTenantId('') | ||||||
|  | 						loginFun() | ||||||
| 					} | 					} | ||||||
| 				}) | 				}) | ||||||
| 			}, | 			}, | ||||||
|   } | 			getxz(index) { | ||||||
|  | 				this.activeid = index | ||||||
|  | 			}, | ||||||
|  | 			goregister() { | ||||||
|  | 				uni.navigateTo({ | ||||||
|  | 					url: '/pages/login/register' | ||||||
|  | 				}) | ||||||
|  | 			}, | ||||||
|  | 			goforgot() { | ||||||
|  | 				uni.navigateTo({ | ||||||
|  | 					url: '/pages/login/forgot' | ||||||
|  | 				}) | ||||||
|  | 			}, | ||||||
|  | 			goselect() { | ||||||
|  | 				console.log('执行去救援', this.sfindex); | ||||||
|  | 				// pages/rescue/trafficPolice | ||||||
|  | 				if (this.sfindex == 'police') { | ||||||
|  | 					uni.reLaunch({ | ||||||
|  | 						url: '/pages/rescue/trafficPolice' | ||||||
|  | 					}) | ||||||
|  | 				} else { | ||||||
|  | 					uni.reLaunch({ | ||||||
|  | 						url: '/pages/rescue/rescue' | ||||||
|  | 					}) | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
|  | 			}, | ||||||
|  | 			// 验证码方法 | ||||||
|  | 			sendVerificationCode() { | ||||||
|  | 				let reg = /^((13[0-9])|(14[0-9])|(15[0-9])|(17[0-9])|(18[0-9]))\d{8}$/; | ||||||
|  | 				if (!reg.test(this.userName)) { | ||||||
|  | 					uni.showToast({ | ||||||
|  | 						icon: 'none', | ||||||
|  | 						title: '请输入正确的11位手机号' | ||||||
|  | 					}) | ||||||
|  | 					this.userName = ''; | ||||||
|  | 					return false; | ||||||
|  | 				} | ||||||
|  | 				if (this.isButtonDisabled) { | ||||||
|  | 					return; // 如果按钮已禁用,则直接返回 | ||||||
|  | 				} | ||||||
|  | 				const data = { | ||||||
|  | 					phone: this.userName, | ||||||
|  | 				} | ||||||
|  | 				request({ | ||||||
|  | 					url: '/loginSmsCode', | ||||||
|  | 					method: 'post', | ||||||
|  | 					params: data | ||||||
|  | 				}).then((res) => { | ||||||
|  | 					console.log('验证码', res); | ||||||
|  | 					if (res.code == 200) { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '验证码已发送 请注意查收', | ||||||
|  | 							icon: 'none' | ||||||
|  | 						}) | ||||||
|  | 					} else { | ||||||
|  | 						uni.showToast({ | ||||||
|  | 							title: '网络不佳请稍后再试', | ||||||
|  | 							icon: 'none' | ||||||
|  | 						}) | ||||||
|  | 					} | ||||||
|  | 				}) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 				this.disableButton(); // 禁用按钮 | ||||||
|  | 				this.startCountdown(); // 启动倒计时 | ||||||
|  | 
 | ||||||
|  | 			}, | ||||||
|  | 			disableButton() { | ||||||
|  | 				this.isButtonDisabled = true; | ||||||
|  | 			}, | ||||||
|  | 			enableButton() { | ||||||
|  | 				this.isButtonDisabled = false; | ||||||
|  | 			}, | ||||||
|  | 			startCountdown() { | ||||||
|  | 				let countdown = setInterval(() => { | ||||||
|  | 					this.countdownTime--; | ||||||
|  | 					if (this.countdownTime === 0) { | ||||||
|  | 						clearInterval(countdown); | ||||||
|  | 						this.enableButton(); // 启用按钮 | ||||||
|  | 					} | ||||||
|  | 				}, 1000); | ||||||
|  | 			}, | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| @ -99,24 +238,29 @@ export default{ | |||||||
| 		font-weight: 400; | 		font-weight: 400; | ||||||
| 		color: #0078FF; | 		color: #0078FF; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	button { | 	button { | ||||||
| 		border: none !important; | 		border: none !important; | ||||||
| 		background: none !important; | 		background: none !important; | ||||||
| 		margin: 0px; | 		margin: 0px; | ||||||
| 		display: block; | 		display: block; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	button:focus { | 	button:focus { | ||||||
| 		color: #0078FF; | 		color: #0078FF; | ||||||
| 		outline: none; | 		outline: none; | ||||||
| 		box-shadow: none; | 		box-shadow: none; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.content { | 	.content { | ||||||
| 		box-sizing: border-box; | 		box-sizing: border-box; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.top { | 	.top { | ||||||
| 		box-sizing: border-box; | 		box-sizing: border-box; | ||||||
| 		padding: 0px 27px; | 		padding: 0px 27px; | ||||||
| 		padding-top: 100px; | 		padding-top: 100px; | ||||||
|  | 		background-image: url('../../static/loginbj.png'); | ||||||
| 		// background-color:lightseagreen; | 		// background-color:lightseagreen; | ||||||
| 		// background-image: url('../../static/loginbj.png'); | 		// background-image: url('../../static/loginbj.png'); | ||||||
| 		background-size: cover; | 		background-size: cover; | ||||||
| @ -124,6 +268,7 @@ button:focus { | |||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		// height: 385px; | 		// height: 385px; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.touxiang { | 	.touxiang { | ||||||
| 		width: 88px; | 		width: 88px; | ||||||
| 		height: 88px; | 		height: 88px; | ||||||
| @ -132,15 +277,18 @@ button:focus { | |||||||
| 		margin: 0 auto; | 		margin: 0 auto; | ||||||
| 		margin-bottom: 40px; | 		margin-bottom: 40px; | ||||||
| 		overflow: hidden; | 		overflow: hidden; | ||||||
|  | 
 | ||||||
| 		image { | 		image { | ||||||
| 			width: 100%; | 			width: 100%; | ||||||
| 			height: 100%; | 			height: 100%; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.twotap { | 	.twotap { | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		display: flex; | 		display: flex; | ||||||
| 		align-items: center; | 		align-items: center; | ||||||
|  | 
 | ||||||
| 		view { | 		view { | ||||||
| 			font-size: 15px; | 			font-size: 15px; | ||||||
| 			font-family: Microsoft YaHei; | 			font-family: Microsoft YaHei; | ||||||
| @ -149,10 +297,12 @@ button:focus { | |||||||
| 			margin-right: 38.5px; | 			margin-right: 38.5px; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.blck { | 	.blck { | ||||||
| 		color: #333333 !important; | 		color: #333333 !important; | ||||||
| 		font-weight: bold !important; | 		font-weight: bold !important; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.inputs { | 	.inputs { | ||||||
| 		box-sizing: border-box; | 		box-sizing: border-box; | ||||||
| 		padding: 16px 0px; | 		padding: 16px 0px; | ||||||
| @ -161,6 +311,7 @@ button:focus { | |||||||
| 		border-bottom: 2px solid #E8E8E8; | 		border-bottom: 2px solid #E8E8E8; | ||||||
| 		margin-top: 20px; | 		margin-top: 20px; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.wjworb { | 	.wjworb { | ||||||
| 		margin-top: 5px; | 		margin-top: 5px; | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| @ -171,6 +322,7 @@ button:focus { | |||||||
| 		align-items: center; | 		align-items: center; | ||||||
| 
 | 
 | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.dl { | 	.dl { | ||||||
| 		width: 90%; | 		width: 90%; | ||||||
| 		height: 44px; | 		height: 44px; | ||||||
| @ -184,6 +336,7 @@ button:focus { | |||||||
| 		align-items: center; | 		align-items: center; | ||||||
| 		margin-top: 22px; | 		margin-top: 22px; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.hging { | 	.hging { | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		text-align: center; | 		text-align: center; | ||||||
| @ -192,6 +345,7 @@ button:focus { | |||||||
| 		color: #636363; | 		color: #636363; | ||||||
| 		margin-top: 20px; | 		margin-top: 20px; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.wx { | 	.wx { | ||||||
| 		width: 38px; | 		width: 38px; | ||||||
| 		height: 38px; | 		height: 38px; | ||||||
| @ -199,11 +353,13 @@ button:focus { | |||||||
| 		box-sizing: border-box; | 		box-sizing: border-box; | ||||||
| 		margin: 0px auto; | 		margin: 0px auto; | ||||||
| 		margin-top: 20px; | 		margin-top: 20px; | ||||||
|  | 
 | ||||||
| 		image { | 		image { | ||||||
| 			width: 100%; | 			width: 100%; | ||||||
| 			height: 100%; | 			height: 100%; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.hui { | 	.hui { | ||||||
| 		font-size: 10px; | 		font-size: 10px; | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| @ -211,6 +367,7 @@ button:focus { | |||||||
| 		font-weight: 400; | 		font-weight: 400; | ||||||
| 		color: #666666; | 		color: #666666; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.dbottom { | 	.dbottom { | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		text-align: center; | 		text-align: center; | ||||||
| @ -219,8 +376,74 @@ button:focus { | |||||||
| 		margin-top: 40px; | 		margin-top: 40px; | ||||||
| 		position: fixed; | 		position: fixed; | ||||||
| 		bottom: 25px; | 		bottom: 25px; | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	.quanzi { | ||||||
|  | 		width: 14px; | ||||||
|  | 		height: 14px; | ||||||
|  | 		border: 1px solid #666666; | ||||||
|  | 		border-radius: 50%; | ||||||
|  | 		margin-right: 10px; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.lanquanzi { | ||||||
|  | 		width: 14px; | ||||||
|  | 		height: 14px; | ||||||
|  | 		border: 1px solid #0078FF; | ||||||
|  | 		border-radius: 50%; | ||||||
|  | 		margin-right: 10px; | ||||||
|  | 		background: #0078FF; | ||||||
|  | 		color: white; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	.lan { | 	.lan { | ||||||
| 		color: #0078FF; | 		color: #0078FF; | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	.jiuzhong { | ||||||
|  | 		width: 90%; | ||||||
|  | 		margin: 10px auto; | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.dist { | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		margin: 0px 10px; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.d-zi { | ||||||
|  | 		font-size: 14px; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.d-qian { | ||||||
|  | 		width: 14px; | ||||||
|  | 		height: 14px; | ||||||
|  | 		margin-right: 5px; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		border-radius: 50%; | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		border: 1px solid #666666; | ||||||
|  | 		color: white; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.d-qian-lan { | ||||||
|  | 		width: 14px; | ||||||
|  | 		height: 14px; | ||||||
|  | 		margin-right: 5px; | ||||||
|  | 		overflow: hidden; | ||||||
|  | 		border-radius: 50%; | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		background: #0078FF; | ||||||
|  | 		border: 1px solid #0078FF; | ||||||
|  | 		color: white; | ||||||
|  | 	} | ||||||
| </style> | </style> | ||||||
							
								
								
									
										
											BIN
										
									
								
								static/loginbj.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/loginbj.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 67 KiB | 
							
								
								
									
										
											BIN
										
									
								
								static/xinlogo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/xinlogo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 25 KiB | 
		Loading…
	
		Reference in New Issue
	
	Block a user