💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
uni这里使用的是插件市场下载的商城模板。 先在main.js里定义一下服务器路径,其他页面可以跟方便引用。 main.js代码: import Vue from 'vue' import App from './App' Vue.config.productionTip = false App.mpType = 'app' Vue.prototype.imageServer = 'http://192.168.43.238/tpshop/public'; Vue.prototype.staticServer = 'http://192.168.43.238/tpshop/public/index.php/'; // Vue.prototype.imageServer = 'http://192.168.50.214/tpshop/public'; // Vue.prototype.staticServer = 'http://192.168.50.214/tpshop/public/index.php/'; const app = new Vue({ ...App }) app.$mount() 对于这个vue.prototype网上是这样解释的: 当你在main.js里声明了Vue.prototype.a = 1后,因为你的每一个vue组件都是一个Vue对象的实例,所以即使你没有在组件内部使用data(){return{……}}声明a,你依然可以在组件中通过this.a来访问。 当然,你也可以在组件中添加一个变量a,这时你访问的就是你在组件中添加的a,而不再是之前在原型中添加的a了,当然你对组件的a继续修改即不会影响原型中的a和其他组建中的a,就类似于下面这段代码(Form是一个自定义对象类型,Vue也可以看作一个自定义对象类型,而每个.vue文件就是一个对象的实例) 好了,main.js这里已经完成了 接下来我们看一下模板里的登陆与注册功能,uni这个框架使用了vue.js为基础开发的,所以使用上可能与之前的js与html这些不太一样,不够会js的话还是可以很好看懂理解和使用的,大概三天时间就能搞懂了。有vue.js知识的话就更容易了。 看一下register.vue的代码: <template> <view> <view class="logo"> <view class="img"> <image mode="widthFix" src=""></image> </view> </view> <view class="form re"> <view class="username"> <view class="get-code" :style="{'color':getCodeBtnColor}" @click.stop="getCode()"></view> <input placeholder="请输入手机号" v-model="phoneNumber" placeholder-style="color: rgba(255,255,255,0.8);"/> </view> <view class="password"> <input placeholder="请输入密码" v-model="passwd" password=true placeholder-style="color: rgba(255,255,255,0.8);"/> </view> <view class="password"> <input placeholder="请确认密码" v-model="aspasswd" password=true placeholder-style="color: rgba(255,255,255,0.8);"/> </view> <view class="btn" @tap="doReg">立即注册</view> <view class="res"> <view @tap="toLogin">已有账号立即登录</view> </view> </view> </view> </template> <script> import md5 from "@/common/SDK/md5.min.js"; export default { data() { return { phoneNumber:"", code:'', passwd:"", aspasswd:"", getCodeBtnColor:"#ffffff", getCodeisWaiting:false } }, onLoad() { }, methods: { Timer(){}, doReg(){ // 隐藏软键盘api uni.hideKeyboard() //模板示例部分验证规则 if(!(/^1(3|4|5|6|7|8|9)\d{9}$/.test(this.phoneNumber))){ uni.showToast({title: '请填写正确手机号码',icon:"none"}); return false; } if(this.passwd == ''){ uni.showToast({title: '未输入密码',icon:"none"}); return false; } if(this.passwd != this.aspasswd){ uni.showToast({title: '两次密码不一致',icon:"none"}); return false; } // setTimeout(function(){ // uni.hideLoading() // },2000) uni.request({ // key: 'UserList', url:this.staticServer+'index/register/register', method: 'POST', dataType:'json', data:{ username:this.phoneNumber, password:this.passwd }, header:{ 'content-type':'application/x-www-form-urlencoded' }, success:(res)=>{ if(res.data == 'jsfl45sfdsfd'){ console.log(res.data); uni.showToast({title:'用户名已存在',icon:"success"}); }else{ uni.setStorage({ key: 'UserList', data: [{username:this.phoneNumber,passwd:md5(this.passwd)}], success: function () { uni.showToast({title:'注册成功',icon:"success"}); // 设定一个定时器。在定时到期以后执行注册的回调函数 setTimeout(function(){ uni.switchTab({url:'../tabBar/user/user'}); },500) } }); } }, fail:(e)=>{ uni.showToast({title:'错误',icon:"success"}); console.log('error'); //新建UserList // 将数据存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容,这是一个异步接口。 } }); }, toLogin(){ uni.hideKeyboard() uni.redirectTo({url:'login'}); uni.navigateBack(); } } } </script> <style lang="scss"> @import "../../static/css/login.scss"; </style> 看起来和js并没有很大区别,只不过可以直接在标签上执行循环与事件了,用起来比较简洁,发起请求用的是uni.request方法,使用方法与ajax并没有太大差别,不过多了一个请求头:header:{ 'content-type':'application/x-www-form-urlencoded' }, 之前用jquery来实现ajax倒是没有注意到这个东西,而且php接收端那边还要做一个跨域处理,不然就会有报错了。 对了php端我用的是thinkphp的框架,方便快捷,而且安全性的方面不用过多考虑,当然框架有问题也会牵连到自己的项目。 register.php代码: ~~~ <?php namespace app\index\controller; // 制定允许其他域名访问 header("Access-Control-Allow-Origin:*"); // 响应类型 header('Access-Control-Allow-Methods:POST'); // 响应头设置 header('Access-Control-Allow-Headers:x-requested-with, content-type'); use think\Controller; use think\Db; use think\Session; class Register extends Controller{ public function register(){ $username = $_POST['username']; $passwords = $_POST['password']; $info = Db::name('name'); $user = $info->where('username','=',$username)->select(); if (!empty($user)){ $list = 'jsfl45sfdsfd'; }else{ $password = md5($passwords); $info->insert(['username'=>$username,'password'=>$password]); $userId = $info->getLastInsID(); session::set('user_id',$userId); session::set('susername',$username); session::set('spassword',$password); $list = 'klajsfl2515'; } echo json_encode($list); } } ~~~