微信小程序 POST请求(网络请求)详解及实例代码


Posted in Javascript onNovember 16, 2016

微信小程序 POST请求

微信小程序开发中网络请求必不可少.GET.POST请求是最常用的.GET请求,POST请求的时候有好几个坑.我已经为大家填好了.

<img src="http://img.blog.csdn.net/20161017170933243?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" align="middle" alt="" />

按照文档,肯定是这么写.那就入坑了.

1. 'Content-Type': 'application/json'用在get请求中没问题.

POST请求就不好使了.需要改成: "Content-Type": "application/x-www-form-urlencoded"

2016.11.10更新:有同学在将content-type 修改为小写后,post请求成功.

2. 加上method: "POST"

3.data: { cityname: "上海", key: "1430ec127e097e1113259c5e1be1ba70" }写成json格式这样也是请求不到数据的.需要转格式.

下面直接贴代码:

 3.1

<span style="font-size:24px;">//index.js 
//获取应用实例 
var app = getApp() 
Page( { 
 data: { 
  toastHidden: true, 
  city_name: '', 
 }, 
 onLoad: function() { 
  that = this; 
  wx.request( { 
   url: "http://op.juhe.cn/onebox/weather/query", 
   header: { 
    "Content-Type": "application/x-www-form-urlencoded" 
   }, 
   method: "POST", 
   //data: { cityname: "上海", key: "1430ec127e097e1113259c5e1be1ba70" }, 
   data: Util.json2Form( { cityname: "上海", key: "1430ec127e097e1113259c5e1be1ba70" }), 
   complete: function( res ) { 
    that.setData( { 
     toastHidden: false, 
     toastText: res.data.reason, 
     city_name: res.data.result.data.realtime.city_name, 
     date: res.data.result.data.realtime.date, 
     info: res.data.result.data.realtime.weather.info, 
    }); 
    if( res == null || res.data == null ) { 
     console.error( '网络请求失败' ); 
     return; 
    } 
   } 
  }) 
 }, 
 onToastChanged: function() { 
  that.setData( { toastHidden: true }); 
 } 
}) 
var that; 
var Util = require( '../../utils/util.js' );</span>

3.2

<span style="font-size:24px;"><!--index.wxml--> 
<view class="container"> 
  <toast hidden="{{toastHidden}}" bindchange="onToastChanged"> 
    {{toastText}} 
  </toast> 
  <view>{{city_name}}</view> 
  <view>{{date}}</view> 
  <view>{{info}}</view> 
</view></span>

3.3

<span style="font-size:24px;">//util.js 
function json2Form(json) { 
  var str = []; 
  for(var p in json){ 
    str.push(encodeURIComponent(p) + "=" + encodeURIComponent(json[p])); 
  } 
  return str.join("&"); 
} 
module.exports = { 
 json2Form:json2Form, 
}</span>

微信小程序 POST请求(网络请求)详解及实例代码

希望对大家有帮助.

Javascript 相关文章推荐
使用apply方法处理数组的三个技巧[译]
Sep 20 Javascript
js和jquery如何获取图片真实的宽度和高度
Sep 28 Javascript
JavaScript设计模式之建造者模式介绍
Dec 28 Javascript
js实现顶部可折叠的菜单工具栏效果实例
May 09 Javascript
javascript处理a标签超链接默认事件的方法
Jun 29 Javascript
JavaScript闭包_动力节点Java学院整理
Jun 27 Javascript
ztree实现左边动态生成树右边为内容详情功能
Nov 03 Javascript
浅谈Vue.js 中的 v-on 事件指令的使用
Nov 25 Javascript
小程序表单认证布局及验证详解
Jun 19 Javascript
利用React高阶组件实现一个面包屑导航的示例
Aug 23 Javascript
在Vue中使用Select选择器拼接label的操作
Oct 22 Javascript
浅谈es6中的元编程
Dec 01 Javascript
微信小程序 swiper组件轮播图详解及实例
Nov 16 #Javascript
input框中的name和id的区别
Nov 16 #Javascript
微信小程序 页面传参实例详解
Nov 16 #Javascript
JS中关于事件处理函数名后面是否带括号的问题
Nov 16 #Javascript
微信小程序 时间格式化(util.formatTime(new Date))详解
Nov 16 #Javascript
jQuery实现的购物车物品数量加减功能代码
Nov 16 #Javascript
使用JavaScript获取URL中的参数(两种方法)
Nov 16 #Javascript
You might like
php自动获取目录下的模板的代码
2010/08/08 PHP
php实例分享之mysql数据备份
2014/05/19 PHP
php读取der格式证书乱码解决方法
2015/06/22 PHP
php微信开发之带参数二维码的使用
2016/08/03 PHP
Laravel框架生命周期与原理分析
2018/06/12 PHP
JS获取scrollHeight问题想到的标准问题
2007/05/27 Javascript
使用javascript获取flash加载的百分比的实现代码
2011/05/25 Javascript
基于jquery的大众点评,分类导航实现代码
2011/08/23 Javascript
JavaScript DOM 编程艺术(第2版)读书笔记(JavaScript的最佳实践)
2013/10/01 Javascript
JS数组去重与取重的示例代码
2014/01/24 Javascript
推荐10个2014年最佳的jQuery视频插件
2014/11/12 Javascript
JavaScript通过Date-Mask将日期转换成字符串的方法
2015/06/04 Javascript
Javascript常用小技巧汇总
2015/06/24 Javascript
每天一篇javascript学习小结(属性定义方法)
2015/11/19 Javascript
canvas时钟效果
2017/02/16 Javascript
详解微信小程序设置底部导航栏目方法
2017/06/29 Javascript
vue.js中父组件调用子组件的内部方法示例
2017/10/22 Javascript
Vue-cli@3.0 插件系统简析
2018/09/05 Javascript
浅谈JavaScript_DOM学习篇_图片切换小案例
2019/03/19 Javascript
vue+element树组件 实现树懒加载的过程详解
2019/10/21 Javascript
浅谈vuex的基本用法和mapaction传值问题
2019/11/08 Javascript
[50:24]VGJ.S vs Pain 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
python实现发送邮件功能
2017/07/22 Python
Python之多线程爬虫抓取网页图片的示例代码
2018/01/10 Python
Python机器学习之K-Means聚类实现详解
2018/02/22 Python
在PyCharm中实现关闭一个死循环程序的方法
2018/11/29 Python
Python 输出时去掉列表元组外面的方括号与圆括号的方法
2018/12/24 Python
详解python爬虫系列之初识爬虫
2019/04/06 Python
python从内存地址上加载python对象过程详解
2020/01/08 Python
TensorFlow2.0:张量的合并与分割实例
2020/01/19 Python
keras 多gpu并行运行案例
2020/06/10 Python
从一次项目重构说起CSS3自定义变量在项目的使用方法
2021/03/01 HTML / CSS
浅析HTML5的WebSocket与服务器推送事件
2016/02/19 HTML / CSS
名词解释WEB SERVICE,SOAP,UDDI,WSDL,JAXP,JAXM;JSWDL开发包的介绍。
2012/10/27 面试题
2015年医院创卫工作总结
2015/04/22 职场文书
Go 中的空白标识符下划线
2022/03/25 Golang