新乡市做微信小程序_微信小程序 PHP后端form表单提交实例详解

  • 栏目:公司新闻 时间:2021-01-12 15:12 分享新闻到:
<返回列表

微信小程序 PHP后端form表单提交实例详解     投稿:lqh   这篇文章主要介绍了微信小程序 PHP后端form表单提交实例详解的相关资料,需要的朋友可以参考下

微信小程序 PHP后端form表单

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

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

3.目录图

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

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

5.Wxml文件代码

 view 
 image src="../../images/return.png" / 
 /view 
 view 
 form bindsubmit="formSubmit" 
 view 
 label for="name" image src="../../images/phone.png" / /label 
 input id="name" name="mobile" type="text" placeholder="请输入手机号" / 
 /view 
 view 
 label for="password" image src="../../images/code.png" / /label 
 input id="password" type="password" placeholder="请输入验证码" / 
 button hover- 获取验证码 /button 
 /view 
 view 
 label for="password" image src="../../images/password.png" / /label 
 input id="password" name="password" type="password" placeholder="请设置6-20位登录密码" / 
 /view 
 view 
 label for="repassword" image src="../../images/password.png" / /label 
 input id="repassword" name="repassword" type="password" placeholder="请输入确认密码" / 
 /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: {

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 foo(this)”this对象,小程序封装了许多内置的调用方法,e.detail.value.mobile 就是当前对象name=”mobile”的对象的值e.detail.value.mobile.length就是这个值的长度

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

9.重点来了

wx.request({ 
 url: '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: ,
 icon: 'loading',
 duration: 1500
 }else{
 wx.showToast({
 title: ,//这里打印出登录成功
 icon: 'success',
 duration: 1000
fail:function(){
 wx.showToast({
 title: '服务器网络错误!',
 icon: 'loading',
 duration: 1500

 这里

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

比如: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: ,
 icon: 'loading',
 duration: 1500
}else{
 wx.showToast({
 title: ,
 icon: 'success',
 duration: 1000

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

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

f.


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

1.POST通过数据到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;

分享新闻到:

更多阅读

新乡市做微信小程序_微信小程序 PHP后端

公司新闻 2021-01-12
手机微信微信小程序 PHP后端开发form表格递交案例详细说明 文章投稿:lqh 本文关键详细介...
查看全文

百度智能小程序是什么_JavaScript 巧学巧用

公司新闻 2021-01-12
JavaScript 巧学妙用 文章投稿:mdxy-dxy 文中关键给大伙儿共享一下在撰写JavaScript编码的情况...
查看全文

广州凡科互联网科技股份有限公司招聘培

公司新闻 2021-01-11
招聘人数:27职位信息岗位职责:1、根据公司要求组织和跟进产品、活动项目培训、沙龙会;...
查看全文
返回全部新闻


区域站点: 南丰县自助建站   南宫市自己建网站   囊谦县网站建设   南和县免费建站   南华县自助建站   南江县自己建网站   南京市网站建设   南靖县免费建站   南康市自助建站   南乐县自己建网站   南陵县网站建设   南宁市免费建站   南平市自助建站   南皮县自己建网站   南市区网站建设   南通市免费建站   南投县自助建站   南雄市自己建网站   南溪县网站建设   南阳市免费建站   南漳县自助建站   南召县自己建网站   南郑县网站建设   那坡县免费建站   那曲县自助建站   纳雍县自己建网站   讷河市网站建设   内黄县免费建站   内江市自助建站   内丘县自己建网站   内乡县网站建设   嫩江市免费建站   聂荣县自助建站   尼玛县自己建网站   尼木县网站建设   宁安市免费建站   宁波市自助建站   宁城县自己建网站   宁德市网站建设   宁都县免费建站   宁国市自助建站   宁海县自己建网站   宁化县网站建设   宁晋县免费建站   宁陵县自助建站   宁明县自己建网站   宁南县网站建设   宁强县免费建站   宁陕县自助建站   宁武县自己建网站   宁乡市网站建设   宁阳县免费建站   宁远县自助建站   农安县自己建网站   磐安县网站建设   盘锦市免费建站   盘山县自助建站   磐石市自己建网站   盘州市网站建设   蓬安县免费建站   澎湖县自助建站   蓬莱市自己建网站   彭山县网站建设   蓬溪县免费建站   彭阳县自助建站   彭泽县自己建网站   彭州市网站建设   偏关县免费建站   平安县自助建站   平昌县自己建网站   平定县网站建设   屏东县免费建站   平度市自助建站   平果县自己建网站   平和县网站建设   平湖市免费建站   平江县自助建站   平乐县自己建网站   平凉市网站建设   平利县免费建站   平罗县自助建站   平陆县自己建网站   屏南县网站建设   平泉市免费建站   屏山县自助建站   平顺县自己建网站   平塘县网站建设   平潭县免费建站   平武县自助建站   萍乡市自己建网站   平乡县网站建设   平阳县免费建站   平遥县自助建站   平阴县自己建网站   平邑县网站建设   平远县免费建站   平舆县自助建站   皮山县自己建网站   普安县网站建设   浦北县免费建站   浦城县自助建站   普洱市自己建网站   普格县网站建设   浦江县免费建站   普兰县自助建站   普宁市自己建网站   莆田市网站建设   迁安市免费建站   乾安县自助建站   潜江市自己建网站   潜山市网站建设  

友情链接: 网站建设文章 网站建设 免费建网站域名 免费建站网站一级 手机版

Copyright © 2002-2020 网站建设_免费建站_自助建站_自己建网站_小程序制作 版权所有 (网站地图) 备案号:粤ICP备10235580号