微信小程序 PHP后端form表单提交实例详解


Posted in Javascript onJanuary 12, 2017

微信小程序 PHP后端form表单

1.小程序相对于之前的WEB+PHP建站来说,个人理解为只是将web放到了微信端,用小程序固定的格式前前端进行布局、事件触发和数据的输送和读取,服务器端可以用任何后端语言写,但是所有的数据都要以JSON的形式返回给小程序。

2.昨天写了登录注册、忘记密码功能,他们实质上都是一个表单提交操作。因此就拿注册功能来写这个例子。

3.目录图

  1. js文件是逻辑控制,主要是它发送请求和接收数据,
  2. json 用于此页面局部 配置并且覆盖全局app.json配置,
  3. wxss用于页面的样式设置,
  4. wxml就是页面,相当于html

4.样式和json文件暂时不管了,我只是想回顾一下form表单的提交

5.Wxml文件代码

<view class="load-head">

  <image src="../../images/return.png" />

  注册

</view>

<view class="login">

  <form bindsubmit="formSubmit">

    <view class="field clearfix">

      <label for="name"><image src="../../images/phone.png" /></label>

      <input id="name" name="mobile" class="login-input" type="text" placeholder="请输入手机号" />

    </view>

    <view class="field clearfix">

      <label for="password"><image src="../../images/code.png" /></label>

      <input id="password" class="login-input" type="password" placeholder="请输入验证码" />

      <button class="get-code" hover-class="code-hover">获取验证码</button>

    </view>

    <view class="field clearfix">

      <label for="password"><image src="../../images/password.png" /></label>

      <input id="password" name="password" class="login-input" type="password" placeholder="请设置6-20位登录密码" />

    </view>

    <view class="field clearfix">

      <label for="repassword"><image src="../../images/password.png" /></label>

      <input id="repassword" name="repassword" class="login-input" type="password" placeholder="请输入确认密码" />

    </view>

    

    <button class="btn_login" formType="submit">注册</button>

  </form>

  <view class="reg_forget clearfix">

    <navigator url="../login/index" class="btn_reg">登录</navigator>

    <navigator url="../forget/index" class="btn_forget">忘记密码</navigator>

  </view >

  

</view>

 6.其中几个关键点需要理解

a.Form表单,需要绑定一个submit事件,在小程序中,属性为bindsubmit,

bindsubmit=”formSubmit”   这里的属性值formSubmit,命名可以为符合规范的任意值,相当于以前html中的  onsubmit=”formSubmit()”,是一个函数名,当提交的时候触发formSubmit这个函数事件,这个函数写在js中。

b.其他的属性和之前的HTML差不多,注意的是,表单一定要有name=“value”,后端处理和以前一样,比如name=”username” PHP可以用 $_POST[‘username']来接收。

C.由于小程序没有input submit这个按钮,所以在每个form表单中都要有一个提交按钮,

<button formType="submit">注册</button>,这个按钮就是用来开启提交事件的。

7.index.js代码

Page({

 data: {

  

 },

 formSubmit: function(e) { 

  if(e.detail.value.mobile.length==0||e.detail.value.password.length==0){

   wx.showToast({

    title: '手机号码或密码不得为空!',

    icon: 'loading',

    duration: 1500

   })

   setTimeout(function(){

     wx.hideToast()

    },2000)

  }else if(e.detail.value.mobile.length != 11){

    wx.showToast({

    title: '请输入11位手机号码!',

    icon: 'loading',

    duration: 1500

   })

   setTimeout(function(){

     wx.hideToast()

    },2000)

  }else if(e.detail.value.password.length <6 ||e.detail.value.password.length>20){

    wx.showToast({

    title: '请输入6-20密码!',

    icon: 'loading',

    duration: 1500

   })

   setTimeout(function(){

     wx.hideToast()

    },2000)

  }else if(e.detail.value.password != e.detail.value.repassword){

    wx.showToast({

    title: '两次密码输入不一致!',

    icon: 'loading',

    duration: 1500

   })

   setTimeout(function(){

     wx.hideToast()

    },2000)

  }else{


   wx.request({ 

      url: 'https://shop.yunapply.com/home/Login/register', 

      header: { 

       "Content-Type": "application/x-www-form-urlencoded" 

      },

      method: "POST",

      data:{mobile:e.detail.value.mobile,password:e.detail.value.password},

      success: function(res) {

       if(res.data.status == 0){

         wx.showToast({

          title: res.data.info,

          icon: 'loading',

          duration: 1500

         })

       }else{

         wx.showToast({

          title: res.data.info,//这里打印出登录成功

          icon: 'success',

          duration: 1000

         })

       }

      } 

     })

  }

 }, 

})

8.需要注意的是

Page()这个方法是必须有的,里面放置js对象,用于页面加载的时候,呈现效果

data: {},数据对象,设置页面中的数据,前端可以通过读取这个对象里面的数据来显示出来。

formSubmit: function  小程序中方法都是 方法名:function(),其中function可以传入一个参数,作为触发当前时间的对象

下面是函数的执行,由于验证太多,我只拿一部分出来理解。

if(e.detail.value.mobile.length==0||e.detail.value.password.length==0){

   wx.showToast({

    title: '手机号码或密码不得为空!',

    icon: 'loading',

    duration: 1500

   })

 这里的e,就是当前触发事件的对象,类似于html onclick=“foo(this)”this对象,小程序封装了许多内置的调用方法,e.detail.value.mobile 就是当前对象name=”mobile”的对象的值e.detail.value.mobile.length就是这个值的长度

 showToast类似于JS中的alert,弹出框,title  是弹出框的显示的信息,icon是弹出框的图标状态,目前只有loading 和success这两个状态。duration是弹出框在屏幕上显示的时间。 

9.重点来了

wx.request({ 

      url: 'https://shop.com/home/Login/register', 

      header: { 

       "Content-Type": "application/x-www-form-urlencoded" 

      },

      method: "POST",

      data:{mobile:e.detail.value.mobile,password:e.detail.value.password},

      success: function(res) {

       if(res.data.status == 0){

         wx.showToast({

          title: res.data.info,

          icon: 'loading',

          duration: 1500

         })

       }else{

         wx.showToast({

          title: res.data.info,//这里打印出登录成功

          icon: 'success',

          duration: 1000

         })

       }

      },

fail:function(){

       wx.showToast({

        title: '服务器网络错误!',

        icon: 'loading',

        duration: 1500

       })

      }  

     })

 wx.request({})是小程序发起https请求,注意http是不行的。

 这里

a.url是你请求的网址,比如以前在前端,POST表单中action=‘index.php',这里的index.php是相对路径,而小程序请求的网址必须是网络绝对路径。

比如:https://shop.com/home/Login/register

b.

header: { 

    "Content-Type": "application/x-www-form-urlencoded" 

   },

由于POST和GET传送数据的方式不一样,POST的header必须是

"Content-Type": "application/x-www-form-urlencoded" 

GET的header可以是 'Accept': 'application/json'

c.一定要写明method:“POST”  默认是“GET”,保持大写

data:{mobile:e.detail.value.mobile,password:e.detail.value.password},

这里的data就是POST给服务器端的数据 以{name:value}的形式传送

d.成功回调函数

success: function(res) {

  if(res.data.status == 0){

    wx.showToast({

    title: res.data.info,

    icon: 'loading',

    duration: 1500

    })

}else{

    wx.showToast({

    title: res.data.info,

    icon: 'success',

    duration: 1000

    })

   }

  }

e.success:function()是请求状态成功触发是事件,也就是200的时候,注意,请求成功不是操作成功,请求只是这个程序到服务器端这条线的通的。

fail:function()就是网络请求不成功,触发的事件。

f.

if(res.data.status == 0){

         wx.showToast({

          title: res.data.info,

          icon: 'loading',

          duration: 1500

         })

       }else{

         wx.showToast({

          title: res.data.info,//这里打印出登录成功

          icon: 'success',

          duration: 1000

         })

       }

这里的一段代码是和PHP后端程序有关系的,具体流程是这样的,

1.POST通过数据到https://shop.com/home/Login/register这个接口,用过THINKPHP的就会知道是HOME模块下的Login控制下的register方法

2.register方法根据POST过来的数据,结合数据库进行二次验证,如果操作成功,返回什么,如果操作失败,返回什么

3.后端PHP代码如下:

控制器 LoginController.class.php

/**
 * 用户注册
 */
public function register()
{
  if (IS_POST) {
    $User = D("User");
    if (!$User->create($_POST, 4)) {
      $this->error($User->getError(),'',true);
    } else {
      if ($User->register()){
        $this->success('注册成功!','',true);
      }else{
        $this->error('注册失败!','',true);
      }
    }
  }
}

 模型

UserModel.class.php  的register方法

public function register()
{
  $mobile = I('post.mobile');
  $password = I('post.password');

  $res = D('User')->add(array(
    'mobile'=> $mobile,
    'password'=>md5($password),
    'modifytime'=>date("Y-m-d H:i:s")
  ));

  return $res;
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
javascript new后的constructor属性
Aug 05 Javascript
Jquery弹出层插件ThickBox的使用方法
Dec 09 Javascript
JavaScript页面模板库handlebars的简单用法
Mar 02 Javascript
运行Node.js的IIS扩展iisnode安装配置笔记
Mar 02 Javascript
jquery中trigger()无法触发hover事件的解决方法
May 07 Javascript
jQuery多级手风琴菜单实例讲解
Oct 22 Javascript
JavaScript前端开发之实现二进制读写操作
Nov 04 Javascript
使用webpack打包koa2 框架app
Feb 02 Javascript
Nuxt升级2.0.0时出现的问题(小结)
Oct 08 Javascript
jquery实现联想词搜索框和搜索结果分页的示例
Oct 10 jQuery
JavaScript事件冒泡机制原理实例解析
Jan 14 Javascript
一篇文章带你搞懂Vue虚拟Dom与diff算法
Aug 25 Javascript
简单的渐变轮播插件
Jan 12 #Javascript
那些精彩的JavaScript代码片段
Jan 12 #Javascript
JavaScript实现星级评分
Jan 12 #Javascript
angular2倒计时组件使用详解
Jan 12 #Javascript
JavaScript中localStorage对象存储方式实例分析
Jan 12 #Javascript
利用VUE框架,实现列表分页功能示例代码
Jan 12 #Javascript
js中常用的Math方法总结
Jan 12 #Javascript
You might like
一个阿拉伯数字转中文数字的函数
2006/10/09 PHP
php中require和require_once的区别说明
2014/02/27 PHP
php+ajax实现无刷新动态加载数据技术
2015/04/28 PHP
弹出模态框modal的实现方法及实例
2017/09/19 PHP
thinkphp中的多表关联查询的实例详解
2017/10/12 PHP
PHP基于GD2函数库实现验证码功能示例
2019/01/27 PHP
PHP实现简单的协程任务调度demo示例
2020/02/01 PHP
JS中令人发指的valueOf方法介绍
2013/02/22 Javascript
js日期相关函数总结分享
2013/10/15 Javascript
jquery基础教程之deferred对象使用方法
2014/01/22 Javascript
jquery实现当滑动到一定位置时固定效果
2014/06/17 Javascript
使用impress.js制作幻灯片
2015/09/09 Javascript
微信小程序画布圆形进度条显示效果
2020/11/17 Javascript
vue 点击按钮增加一行的方法
2018/09/07 Javascript
使用zrender.js绘制体温单效果
2019/10/31 Javascript
element-ui 文件上传修改文件名的方法示例
2019/11/05 Javascript
布同自制Python函数帮助查询小工具
2011/03/13 Python
python实现登陆知乎获得个人收藏并保存为word文件
2015/03/16 Python
Python sys.argv用法实例
2015/05/28 Python
Python基本socket通信控制操作示例
2019/01/30 Python
Python控制台输出时刷新当前行内容而不是输出新行的实现
2020/02/21 Python
Python读取Excel数据并生成图表过程解析
2020/06/18 Python
Python远程方法调用实现过程解析
2020/07/28 Python
记一次django内存异常排查及解决方法
2020/08/07 Python
Python3如何使用tabulate打印数据
2020/09/25 Python
Python爬虫实现selenium处理iframe作用域问题
2021/01/27 Python
python网络爬虫实现发送短信验证码的方法
2021/02/25 Python
澳大利亚药房在线:ThePharmacy
2017/10/04 全球购物
英国莱斯特松木橡木家具网上商店:Choice Furniture Superstore
2019/07/05 全球购物
error和exception有什么区别
2012/10/02 面试题
大学生暑期实践感言
2014/02/26 职场文书
会计系毕业求职信
2014/08/07 职场文书
2014年行政助理工作总结
2014/11/19 职场文书
护士自荐信怎么写
2015/03/06 职场文书
优秀班干部主要事迹材料
2015/11/04 职场文书
MySQL EXPLAIN输出列的详细解释
2021/05/12 MySQL