WXHL 学习文章连载十三

一、2大管理对象
1.AFHTTPRequestOperationManager
* 对NSURLConnection的封装


2.AFHTTPSessionManager
* 对NSURLSession的封装


二、AFHTTPRequestOperationManager的具体使用
1.创建管理者
AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];


2.封装请求参数
NSMutableDictionary *params = [NSMutableDictionary dictionary];
params[@"username"] = @"哈哈哈";
params[@"pwd"] = @"123";


3.发送请求
NSString *url = @"ansdaksncasnfcm";
[mgr POST:url parameters:params
success:^(AFHTTPRequestOperation *operation, id responseObject) {
// 请求成功的时候调用这个block
NSLog(@"请求成功---%@", responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
// 请求失败的时候调用调用这个block
NSLog(@"请求失败");
}];
// GET请求
[mgr GET:url parameters:params
success:^(AFHTTPRequestOperation *operation, id responseObject) {
// 请求成功的时候调用这个block
NSLog(@"请求成功---%@", responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
// 请求失败的时候调用调用这个block
NSLog(@"请求失败");
}];


三、对服务器返回数据的解析
1.AFN可以自动对服务器返回的数据进行解析
* 默认将服务器返回的数据当做JSON来解析


2.设置对服务器返回数据的解析方式
1> 当做是JSON来解析(默认做法)
* mgr.responseSerializer = [AFJSONResponseSerializer serializer];
* responseObject的类型是NSDictionary或者NSArray


2> 当做是XML来解析
* mgr.responseSerializer = [AFXMLParserResponseSerializer serializer];
* responseObject的类型是NSXMLParser


3> 直接返回data
* 意思是:告诉AFN不要去解析服务器返回的数据,保持原来的data即可
* mgr.responseSerializer = [AFHTTPResponseSerializer serializer];


3.注意
* 服务器返回的数据一定要跟responseSerializer对得上
1> 服务器返回的是JSON数据
* AFJSONResponseSerializer
* AFHTTPResponseSerializer


2> 服务器返回的是XML数据
* AFXMLParserResponseSerializer
* AFHTTPResponseSerializer


3> 服务器返回的是其他数据
* AFHTTPResponseSerializer
1. 在微信开发者工具中创建一个小程序项目,选择“空白模板”。 2. 在项目根目录下创建 pages/register 目录,并在该目录下创建四个文件:register.wxml、register.wxss、register.js、register.json。 3. 在 register.json 中配置页面的标题和导航栏颜色。 ``` { "navigationBarTitleText": "注册", "navigationBarBackgroundColor": "#ffffff", "navigationBarTextStyle": "black" } ``` 4. 在 register.wxml 中编写页面的结构。使用小程序的表单组件和输入框组件实现输入框和提交按钮。 ``` <view class="form"> <form bindsubmit="submitForm"> <view class="form-item"> <text>姓名:</text> <input type="text" name="name" placeholder="请输入姓名" /> </view> <view class="form-item"> <text>性别:</text> <radio-group name="gender"> <radio value="男">男</radio> <radio value="女">女</radio> </radio-group> </view> <view class="form-item"> <text>出生日期:</text> <picker mode="date" name="birthday"> <view class="picker"> {{birthday}} </view> </picker> </view> <view class="form-item"> <text>部别:</text> <input type="text" name="department" placeholder="请输入部别" /> </view> <view class="form-item"> <text>联系方式:</text> <input type="tel" name="phone" placeholder="请输入联系方式" /> </view> <view class="form-item"> <text>家庭地址:</text> <input type="text" name="address" placeholder="请输入家庭地址" /> </view> <view class="form-item"> <text>家人姓名关系及联系方式:</text> <textarea name="family" placeholder="请输入家人姓名关系及联系方式"></textarea> </view> <button type="submit">提交</button> </form> </view> ``` 5. 在 register.wxss 中编写页面的样式。 ``` .form { padding: 20rpx; } .form-item { display: flex; align-items: center; margin-bottom: 20rpx; } .form-item text { width: 120rpx; font-size: 28rpx; } .form-item input, .form-item textarea { flex: 1; padding: 20rpx; border: 1rpx solid #ccc; border-radius: 5rpx; font-size: 28rpx; } .form-item button { margin-top: 40rpx; padding: 20rpx; background-color: #007aff; color: #ffffff; border-radius: 5rpx; font-size: 28rpx; } ``` 6. 在 register.js 中编写页面的逻辑。实现表单提交功能,将数据保存在本地存储中。 ``` Page({ data: { birthday: '' }, submitForm: function(e) { var formData = e.detail.value; wx.setStorageSync('registerData', formData); wx.showToast({ title: '注册成功', icon: 'success', duration: 2000, success: function() { wx.navigateBack(); } }) }, bindDateChange: function(e) { this.setData({ birthday: e.detail.value }) } }) ``` 7. 在 app.json 中配置页面的路由。 ``` { "pages": [ "pages/register/register" ], "window": { "backgroundTextStyle": "light", "navigationBarBackgroundColor": "#fff", "navigationBarTitleText": "WeChat", "navigationBarTextStyle": "black" } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值