uni-app前端用户登录实现

从0开始开发SpringBoot+vue前后端分离项目

后端

  1. Springboot简单实现用户登录操作


1、HBuildX:uni-app创建项目

安装编辑器不再一一赘述,网上有很多教程。

填写项目名称,vue版本选择2
在这里插入图片描述


一、项目目录结构

在这里插入图片描述

uni-modules这个模块是导入的,
只需要导入一个 uni-ui 组件即可,导入链接:https://ext.dcloud.net.cn/plugin?id=55

二、创建login.vue

创建完成后,需注意
pages.json中,添加该页面路径
完整pages.json如下:

{
	"pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
		{
			"path": "pages/login/login",
			"style": {
				"navigationBarTitleText": "登录页"
			}
		},
		{
			"path": "pages/index/index",
			"style": {
				"navigationBarTitleText": "uni-app"
			}
		}
	],
	"globalStyle": {
		"navigationBarTextStyle": "black",
		"navigationBarTitleText": "uni-app",
		"navigationBarBackgroundColor": "#F8F8F8",
		"backgroundColor": "#F8F8F8"
	},
	"uniIdRouter": {}
}

三、login.vue

完整代码

//第一种是简单登录
<template>
	<view>
		<view class="margin bg-fff padding-xl radius shadow-warp bg-white margin-top">
			<!-- 图标 -->
			<view  style="width: 100%;">
				<image class="avatar" src="../../static/img/1.png" mode="" style="width: 100%;"></image>
			</view>
			<!-- 账号密码 -->
			<view class="login_form"  >
				<view class="login_form_input">
					<view name="username">
						<uni-easyinput v-model="form.username" prefixIcon="person" placeholder="请输入登录用户名"
							@blur="insert($event)">
						</uni-easyinput>
					</view>
					<view name="password">
						<uni-easyinput type="password" v-model="form.password" prefixIcon="locked" placeholder="请输入登录密码"
							@blur="insert($event)"></uni-easyinput>
					</view>

				</view>
			</view>
			<p>{{message}}</p>
		</view>
		<!-- 按钮 -->
		<button class="btn" type="primary" @click="onLogin()" style="width: 80%;margin-left: 10%;margin-top: 8vw;">登录</button>
		<navigator url="xxxx" style="margin: 10rpx 40rpx; color: deepskyblue;">前往注册</navigator>



	</view>
</template>

<script>
	export default {
		data() {
			return {
				message: "",
				form: {}
			}
		},
		methods: {
			// then方式的 .then 要这样获取,不要用res就好了 会跟内部定义的属性名冲突 
			//这个是固定死的登陆方法
			onLogin() {
				uni.request({
					url: "http://localhost:8082/login",
					data: {
						userName: this.form.username,
						userPassword: this.form.password
					},
					method: "POST",

				}).then(result => {
					// 登陆成功的结果
					console.log(result)
					if (result[1].data == "success") {

						uni.navigateTo({
							url: "/pages/index/index"
						})
						
					} else {
						uni.showToast({
							title: '登录失败',
							duration: 2000,
							icon: 'error'
						});

					}

				})
			},
			insert(e) {
				if (!e.target.value.trim())
					this.message = "输入不能为空"

			}

		}
	}
</script>

其中

	uni.request({
					url: "http://localhost:8082/login",
					data: {
						userName: this.form.username,
						userPassword: this.form.password
					},
					method: "POST",

				})

向后台请求数据的url是spring后台项目中接口地址
url: "http://localhost:8082/login"
跳转的页面,暂时用的就是自动生成的index就不再粘贴代码了,后面会进行修改

四、效果展示

在这里插入图片描述
登录失败:
在这里插入图片描述
登录成功后,进入主页:
在这里插入图片描述

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: uni-app 是一个使用 Vue.js 开发跨平台应用的框架。在 uni-app实现前端登录功能,通常有以下几种方式: 1. 使用 uni.login() 方法获取微信小程序的登录凭证 code,然后将 code 发送给后端服务器,由服务器使用 code 换取 openid 和 session_key。 2. 在前端页面中使用表单提交用户名和密码到服务器,由服务器验证用户名和密码并返回 token。 3. 使用第三方登录服务,如微信登录、QQ 登录、微博登录等。 具体实现方式取决于你的业务需求和服务端的接口。 ### 回答2: uni-app是一种基于Vue.js的跨平台开发框架,可以一次编写代码,同时生成可以运行在多个平台(iOS、Android、Web等)上的应用程序。下面是一个基本的uni-app前端登录示例。 1. 创建登录页面:在uni-app中,可以使用Vue的模板语法来创建登录页面,包括输入用户名和密码的表单,以及登录按钮。 2. 数据绑定:使用Vue的双向数据绑定,将输入框中的用户名和密码与页面的数据进行绑定,以便可以在登录时获取用户输入的值。 3. 发起登录请求:当用户点击登录按钮时,可以通过uni-app提供的API发起登录请求,将用户名和密码作为参数传递给后端接口。 4. 处理登录结果:根据后端接口返回的数据进行处理,可以使用异步回调函数或者Promise等方式进行处理。根据登录结果,可以给出相应的提示信息,如登录成功或登录失败。 5. 登录成功后的操作:如果登录成功,可以进行一些额外的操作,比如跳转到首页、保存用户登录状态等。 6. 错误处理:如果登录失败,可以给出相应的提示信息,如用户名或密码错误等。 7. 表单验证:可以添加一些简单的前端表单验证,如判断用户名和密码是否为空,输入是否符合要求等。 总结:以上是一个简单的uni-app前端登录流程,通过创建登录页面、数据绑定、发起登录请求、处理登录结果、登录成功后的操作以及错误处理等步骤,实现了一个基本的前端登录功能。当然,具体的实现还可以根据实际需求进行扩展和优化。 ### 回答3: uni-app是一个跨平台的开发框架,可以同时开发iOS、Android和H5应用。实现前端登录功能,我们可以借助uni-app提供的一些工具和技术来完成。 首先,我们需要创建一个登录页面,包括用户名和密码的输入框以及登录按钮。用户输入用户名和密码后,点击登录按钮可以触发相应的登录事件。 在uni-app中,我们可以使用Vue.js来处理用户输入和点击事件。可以在data中定义一个对象,用于保存用户名和密码的值。然后,使用v-model指令将输入框的值与data中的对象绑定起来,这样用户在输入框中输入的内容会自动同步到对应的data对象中。 当用户点击登录按钮时,可以通过调用uni-app提供的API发送登录请求到后端服务器。可以使用uni.request方法发送HTTP请求,并传递用户名和密码作为请求参数。可以在请求成功的回调函数中进行相应的处理,比如保存用户登录状态等。 在前端登录过程中,还可以使用uni-app提供的拦截器(interceptor)来处理用户登录状态。在每次请求发送前,可以通过拦截器判断用户是否已登录,如果未登录则跳转到登录页面进行认证,否则继续发送请求。 此外,为了提高用户体验和安全性,还可以使用uni-app的本地存储功能来保存用户登录状态和登录凭证。可以使用uni.setStorage方法将用户登录信息保存到本地存储中,并使用uni.getStorage方法从本地存储中获取用户登录信息。 总的来说,uni-app前端登录需要创建登录页面,处理用户输入和点击事件,发送登录请求到后端服务器,并根据返回结果判断登录是否成功。同时,还需要使用拦截器来处理用户登录状态,以及使用本地存储来保存登录信息。通过这些步骤,我们就可以实现uni-app前端登录功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

头发还不秃的秃头程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值