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);
}
}
~~~