<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                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); } } ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看