6-API应用

6-1:网络API

wx.request(Object)接口 用于发起HTTPS请求。
wx.uploadFile(Object)接口 用于将本地资源上传到后台服务器。
wx.downloadFile(Object)接口 用于下载文件资源到本地。
wx.connectSocket(Object)接口 用于创建一个WebSocket连接。
wx.sendSocketMessage(Object)接口 用于实现通过WebSocket连接发送数据。
wx.closeSocket(Object)接口 用于关闭WebSocket连接。
wx.onSocketOpen(CallBack)接口 用于监听WebSocket连接打开事件。
wx.onSocketError(CallBack))接口 用于监听WebSocket错误。
wx.onSocketMessage(CallBack)接口 用于实现监听WebSocket接收到服务器的消息事件。
wx.onSocketClose(CallBack)接口 用于实现监听WebSocket关闭。

6-1-1:发起网络请求

wx.request(qbject)实现向服务器发送请求、获取数据等各种网络交互操作

通过wx.request(qbject)获取百度(https://www.baidu.com)首页的数据

//wxml
<button type="primary"bindtap="getbaidutap">获取HTML数据</button>
<textarea value='{{html}}'auto-heightmaxlength='0'></textarea>


//js
Page({
  data:{
    html:""
  },
  getbaidutap:function(){
    var that=this;
    wx.request({
      url: 'https://www.baidu.com',
      data:{},
      header:{'content-type':'application/json'},
      success:function(res){
        console.log(res);
        that.setData({
          html:res.data
        })
      }
    })
  }
})

通过wx.request(qbject)的GET方法获取邮政编码对应的地址信息

//wxml
<view>邮政编码:</view>
<input type="text"bindinput="input"placeholder='6位邮政编码'/>
<button type="primary"bindtap="find">查询</button>
<block wx:for="{{address}}">
    <block  wx:for="{{item}}">
       <text>{{item}}</text>
    </block>
</block>



//js
Page({
  data:{
    postcode:"",
    address:[],
    errmsg:"",
    error_code:-1
  },
  input:function(e){
    this.setData({
      postcode:e.detail.value,
    })
    console.log(e.detail.value)
  },
  find:function(){
    var postcode=this.data.postcode;
    if(postcode!=null&&postcode!=""){
       var self=this;
       wx.showtoast({
         title:'正在查询,请稍后....',
         icon:'loading',
         duration:10000
       });
       wx.request({
         url: 'https://v.juhe.cn/postcode/query',
         data:{
           'postcode':postcode,
           'key':'0ff9bfccdf147476e067de994eb5496e'
         },
         header:{
           'content-type':'application/json',
         },
         method:'GET',
         success:function(res){
           wx.hideToast();
           if(res.data.error_code==0){
             console.log(res);
             self.setData({
               errmsg:"",
               error_code:res.data.error_code,
               address:res.data.result.list
             })
           }
           else{
             self.setData({
               errmsg:res.data.reason||res.data.reason,
               error_code:res.data.error_code
             })
           }
         }
       })
    }
  }
})

通过wx.request(object)的post方法获取邮政编码对应的地址信息

//wxml
<view>邮政编码:</view>
<input type="text"bindinput="input"placeholder='6位邮政编码'/>
<button type="primary"bindtap="find">查询</button>
<block wx:for="{{address}}">
    <block  wx:for="{{item}}">
       <text>{{item}}</text>
    </block>
</block>


//js
Page({
  data:{
    postcode:"",
    address:[],
    errmsg:"",
    error_code:-1
  },
  input:function(e){
    this.setData({
      postcode:e.detail.value,
    })
    console.log(e.detail.value)
  },
  find:function(){
    var postcode=this.data.postcode;
    if(postcode!=null&&postcode!=""){
       var self=this;
       wx.showtoast({
         title:'正在查询,请稍后....',
         icon:'loading',
         duration:10000
       });
       wx.request({
         url: 'https://v.juhe.cn/postcode/query',
         data:{
           'postcode':postcode,
           'key':'0ff9bfccdf147476e067de994eb5496e'
         },
         header:{
           'content-type':'application/x-www-form-urlencoded',
         },
         method:'post',
         success:function(res){
           wx.hideToast();
           if(res.data.error_code==0){
             console.log(res);
             self.setData({
               errmsg:"",
               error_code:res.data.error_code,
               address:res.data.result.list
             })
           }
           else{
             self.setData({
               errmsg:res.data.reason||res.data.reason,
               error_code:res.data.error_code
             })
           }
         }
       })
    }
  }
})

6-1-2:上传文件

wx.uploadfile(object)接口用于将本地资源上传到开发者服务器,并在客户端发起一个HTTPS POST请求

通过wx.uploadfile(object),可以将图片上传到服务器并显示

//wxml
<button type="primary"bindtap="uploadimage">上传图片</button>
<image src="{{img}}"mode="widthfix"/>



//js
Page({
  data:{
    img:null,
  },
  uploadimage:function(){
    var that=this;
    wx.chooseImage({
      success:function(res){
        var tempfilepaths=res.tempfilepaths
        upload(that,tempfilepaths);
      }
    })
    function upload(page,path){
      wx.showToast({
        icon:"loading",
        title: '正在上传'
      })
      wx.uploadFile({
        filePath: Path[0],
        name: 'file',
        url: "http://localhost/",
        success:function(res){
          console.log(res);
          if(res.statusCode!=200){
            wx.showModal({
              title: '提示',
              content: '上传失败',
              showCancel:false
            })
            return;
          }
          var data=res.data
          page.setdata({//上传成功修改显示头像
          img:path[0]
        })
        },
        fail:function(e){
          console.log(e);
          wx.showModal({
            title: '提示',
            content: '上传失败',
              showCancel:false
          })
        },
        complete:function(){
          wx.hideToast();
        }
      })
    }
  }
})

6-1-3:下载文件

wx.downloadfile(object)接口用于实现从开发者服务器下载文件资源到本地,在客户端直接发起一个HTTP GET请求,返回文件的本地临时路径

//wxml
<button type="primary"bindtap="downloadimage">下载图像</button>
<image src="{{img}}"mode="widthfix"style="widyh:90%;height:500px"></image>





//js
Page({
  data:{
    img:null,
  },
  downloadimage:function(){
    var that=this;
    wx.downloadfile({
      url:"http://localhost/1.jpg",
      success:function(res){
        console.log(res);
        that.setData({
          img:res.tempfilepath
        })
    }
})
  }
})

6-2:多媒体API

多媒体API主要包括图片API、录音API、音频播放控制API、音乐播放控制API等,其目的是丰富小程序的页面功能

6-2-1:图片API

1:选择图片或拍照

wx.chooseImage({
  count:2,
  sizeType:['original','compressed'],
  sourceType:['album','camera'],
  success:function(res){
    var tempfilepaths=res.tempFilePaths
    var tempfiles=res.tempFiles;
    console.log(tempfilepaths)
    comsole.log(tempfiles)
  }
})

2:预览图片

wx.previewImage({
  current:"http://bmob-cdn-16488.b0.upaiyun.com/2018/02/05/2.png",
  urls: ["http://bmob-cdn-16488.b0.upaiyun.com/2018/02/05/1.png",
  "http://bmob-cdn-16488.b0.upaiyun.com/2018/02/05/2.png",
  "http://bmob-cdn-16488.b0.upaiyun.com/2018/02/05/3.png",
]
})

3:获取图片信息

wx.chooseImage({
  success:function(res){
    wx.getImageInfo({
      src: res.tempFilePaths[0],
      success:function(e){
        console.log(e.width)
        console.log(height)
      }
    })
  },
})

4:保存图片到系统相册

wx.chooseImage({
  success:function(res){
    wx.saveImageToPhotosAlbum({
      filePath: res.tempFilePaths[0],
      success:function(e){
        console.log(e)
      }
    })
  },
})

6-2-2:录音API

1:开始录音

2:停止录音

wx.startRecord({
  success:function(res){
    var tempFilePath=res.tempFilePath
  },
  fail:function(res){
 
  }
  })
   setTimeout(function(){
     wx.stopRecord()
   },10000)

6-2-3:音频播放控制API

主要包括3个API:

wx.playvoice(object)接口   用于实现开始播放语音

wx.pausevoice(object)接口   用于实现暂停正在播放的语音

wx.stopvoice(object)接口   用于结束播放语音

1:播放语音

wx.startRecord({
  success:function(res){
    var tempfilepath=res.tempFilePath
    wx.playVoice({
      filePath: tempfilepath,
      complete:function(){
      }
    })
  }
})

2:暂停播放

wx.startRecord({
  success:function(res){
    var tempfilepath=res.tempFilePath
    wx.playVoice({
      filePath: tempfilepath,
    })
    setTimeout(function(){
      wx.pauseVoice() 
    },5000)
  }
})

3:结束播放

wx.startRecord({
  success:function(res){
    var tempfilepath=res.tempFilePath
    wx.playVoice({
      filePath: tempfilepath,
    })
    setTimeout(function(){
      wx.stopVoice() 
    },5000)
  }
})

6-2-4:音乐播放控制API

wx.playBackgroundAudio(Object)接口    用于播放音乐。    

wx.getBackgroundAudioPlayerState( Object)接口    用于获取音乐播放状态。

wx.seekBackgroundAudio( Object)接口     用于定位音乐播放进度。

wx. pauseBackgroundAudio( )接口    用于实现暂停播放音乐。

wx.stopBackgroundAudio()接口     用于实现停止播放音乐。

wx. onBackgroundAudioPlay(CallBack)接口    用于实现监听音乐播放。

wx.onBackgroundAudioPause(CallBack)接口    用于实现监听音乐暂停。

wx. onBackgroundAudioStop(CallBack)接口    用于实现监听音乐停止。

1:播放音乐

2:获取音乐播放状态

3:控制音乐播放进度

4:暂停播放音乐

wx.pausebackgroundaudio()接口    用于暂停播放音乐

5:停止播放音乐

wx.stopbackgroundaudio()接口    用于停止播放音乐

6:监听音乐播放

wx.onbackgroundaudioplay(callback)接口    用于实现监听音乐播放

7:监听音乐暂停

wx.onbackgroundaudiopause(callback)接口    用于实现监听音乐暂停

8:监听音乐停止

wx.onbackgroundaudiostop(callback)接口    用于实现监听音乐停止

9:案例展示

//wxml
<view class="container">
<image class="bgaudio" src="{{changedImg?music.coverImg:'../image/aaa.jpg'}}"/>
<view class="control-view">
<image src="../image/bbb.jpg" bindtap="onPositionTap" data-how="0"/>
<image src="../../images/{{isplaying?'pause':'play'}}.png" bindtap="onAudioTap"/>
<image src="../image/ccc.jpg" bindtap="onStopTap"/>
<image src="../image/ccc.jpg" bindtap="onPositionTap" data-how="1"/>
</view>
</view>



//js
Page({
  data:{
    isplaying:false,
    coverImg:"",
      changedImg:false,
       music:{
         "url":"http://bmob-cdn-16488.b0.upaiyun.com/2018/02/09/117e4a1b405195b18061299e2de89597.mp3",
         "title":"盛晓玫-有一天",
         "coverImg":"http://bmob-cdn-16488.b0.upaiyun.com/2018/02/09/f604297140c9681880cc3d3e581f7724.jpg"
       },
  },
  onLoad:function(){
    this.onAudioState();
  },
  onAudioTap:function(event){
    if(this.data.isplaying){
      wx.pauseBackgroundAudio();
    }else{
      let music=this.data.music;
      wx.playBackgroundAudio({
        dataUrl: music.url,
        title:music.title,
        coverImgUrl:music.coverImg
      })
    }
  },
  onStopTap:function(){
    let that=this;
    wx.stopBackgroundAudio({
      success:function(){
        that.setData({
          isplaying:false,changedImg:false
        });
      }
    })
  },
  onPositionTap:function(event){
    let how=event.target.dataset.how;
    wx.getBackgroundAudioPlayerState({
      success:function(res){
        let status=res.status;
        if(status===1){
          let duration=res.duration;
          let currentPosition=res.currentPosition;
          if(how==="0"){
            let position=currentPosition-10;
            if(position<0){
              position=1;
            }
            wx.setBackgroundAudio({
              position:position
            });
            wx.showToast({
              title: '快退10s',
              duration:500
            });
          }
          if(how==="1"){
            let position=currentPosition+10;
            if(position>duration){
              position=duration-1;
            }
            wx.seekBackgroundAudio({
              position: position
            });
            wx.showToast({
              title: '快进10s',
              duration:500
            });
          }
        }else{
          wx.showToast({
            title: '音乐未播放',
            duration:800
          });
        }
      }
    })
  },
  onAudioState:function(){
    let that=this;
    wx.onBackgroundAudioPlay(function(){
      that.setData({
        isplaying:true,
        changedImg:true
      });
      console.log("on play");
    });
    wx.onBackgroundAudioPause(function(){
      that.setData({
        isplaying:false
      });
      console.log("on pause");
    });
    wx.onBackgroundAudioStop(function(){
      that.setData({
        isplaying:false,
        changedImg:false
      });
      console.log("on stop")
    });
  }
})



//wxss
.bgaudio{
  height: 350rpx;
  width: 350rpx;
  margin-bottom: 100rpx;
}
.control-viewimage{
  height: 64rpx;
  width: 64rpx;
  margin: 30rpx;
}



//json
{

}

6-3:文件API

主要包括以下5个API接口:
wx. saveFile( Object)接口     用于保存文件到本地。

wx. getSavedFileList(Object)接口    用于获取本地已保存的文件列表。

wx.getSaveFileInfo(Object)接口    用于获取本地文件的文件信息。

wx.removeSaveFile(Object)接口    用于删除本地存储的文件。

wx.openDocument( Object)接口    用于新开页面打开文档,支持格式:doc、xls、    
ppt、pdf、docx、xlsx、ppts。

1:保存文件

Page({
  saveImg:function(){
    wx:wx.chooseImage({
      count: 1,
      sizeType: ['original','compressed'],
      sourceType: ['album','camera'],
      success:function(res){
      var tempfilepaths=res.tempfilepaths[0]
      wx.savefile({
        tempfilepath:tempfilepaths,
        success:function(res){
          var savefilepath=res.savefilepath;
          console.log(savefilepath)
        }
      })
    }
    })
  }
})

2:获取本地文件列表

wx.getSavedFileList({
    success:function(res){
      that.setData({
        fileList:res.fileList
      })
    }
  })

3:获取本地文件的文件信息

wx.chooseImage({
  count:1,
  sizeType:['original','compressed'],
  sourceType:['album','camera'],
    success:function(res){
      var tempFilePaths=res.tempFilePaths[0]
      wx.saveFile({
        tempFilePath:tempFilePaths,
        success:function(res){
          var saveFilePath=res.savedFilePath;
          wx.getSavedFileInfo({
            filePath:saveFilePath,
            success:function(res){
              console.log(res.size)
            }
          })
        }
      })
    }
  })

4:删除本地文件

wx.getSavedFileList({
  success:function(res){
    if(res.fileList.length>0){
    wx.removeSaveFile({
     FilePath:res.fileList[0].filePath,
     complete:function(res){
            console.log(res)
          }
        })
      }
    }
    })

5:打开文档

wx.downloadFile({
  url: "http://localhost/fm2.pdf",
    success:function(res){
      var tempfilepath=res.tempfilepath;
      wx.openDocument({
        filePath:tempfilepath,
        success:function(res){
          console.log("成功打开")
        }
      })
    }
  })

6-4:本地数据及缓存API

6-4-1:保存数据

1:wx.setStorage(Object)

wx.setStorage({
  key:'name',
  data:'sdy',
  success:function(res){
    console.log(res)
  }
})
2:wx.setStorageSync(key,data)

wx.setStorageSync('age', '25')

6-4-2:获取数据

1:wx.setStorage(Object)

wx.getStorage({
  key:'name',
  success:function(res){
    console.log(res.data)
  },
})
2:wx.setStorageSync(key)

try{
  var value =wx.getStorageSync('age')
  if(value){
    console.log("获取成功"+value)
  }
}catch(e){
  console.log("获取失败")
}

6-4-3:删除数据

1:wx.removeStorage(Object)

wx.removeStorage({
  key: 'name',
  success:function(res){
    console.log("删除成功")
  },
  fail:function(){
    console.log("删除失败")
  }
})
2:wx.removeStorageSync(key)

try{
  wx.removeStorageSync('name')
}catch(e){
  
}

6-4-4:清空数据

1:wx.clearStorage()

wx.getStorage({
  key: 'name',
  success:function(res){
   wx.clearStorage()
  },
})
2:wx.clearStorageSync()

try{
  wx.clearStorageSync()
}catch(e){
 
}

6.5:位置信息API

6-5-1:获取位置信息

6-5-2:选择位置信息

wx.chooseLocation({
    success:function(res){
      console.log("位置的名称"+res.longitude)
      console.log("位置的地址"+res.accuracy)
      console.log("位置的纬度"+res.horizontalAccuracy)
      console.log("位置的纬度"+res.verticalAccuracy)
    }
})

6-5-3:显示位置信息

wx.getLocation({
  type:'gcj02',
    success:function(res){
      var latitude=res.latitude
      var longitude=res.longitude
      wx.openLocation({
        latitude: latitude,
        longitude: longitude,
        scale:10,
        name:'智慧国际酒店',
        address:'西安市长安区西长安区300号'
      })
    }
})

6.6:设备相关API

6-6-1:获取系统信息

wx.getSystemInfo({
    success:function(res){
      console.log("手机型号:"+res.model);
      console.log("设备像素比:"+res.pixelRatio);
      console.log("窗口的高度:"+res.windowHeight);
      console.log("窗口的宽度:"+res.windowWidth);
      console.log("微信的版本号:"+res.version);
      console.log("操作系统版本:"+res.system);
      console.log("客户端平台:"+res.platform);
    },
})

6-6-2:网络状态

1:获取网络状态

wx.getNetworkType({
  success:function(res){
    console.log(res.networkType)
  },
})
2:监听网络状态变化

wx.onNetworkStatusChange({function(res){
  console.log("网络是否链接"+res.isConnected)
  console.log("变化后的网络类型"+res.networkType)
}
})

6-6-3:拨打电话

wx.makePhoneCall({
  phoneNumber: '18092585093',
})

6-6-4:扫描二维码

wx.scanCode({
  success:(res)=>{
    console.log(res.result)
    console.log(res.scanType)
    console.log(res.charSet)
    console.log(res.path)
  }
})

  • 36
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值