百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

小程序开发教程学习(二)

liuian 2025-01-20 14:45 11 浏览

八、小程序的API开发

1.wx.request使用:

a.概念:发起HTTPS网络请求

b.参数如下表所示:

属性

类型

默认值

是否必填

说明

支持版本

url

string


开发者服务器接口地址


data

string/object/ArrayBuffer


请求的参数


header

Object


设置请求的 header,header 中不能设置 Referer。

content-type 默认为 application/json


method

string

GET

HTTP 请求方法


dataType

string

json

返回的数据格式


responseType

string

text

响应的数据类型

>= 1.7.0

success

function


接口调用成功的回调函数


fail

function


接口调用失败的回调函数


complete

function


接口调用结束的回调函数(调用成功、失败都会执行)


c.示例代码如下:

wx.request({

url: 'test.php', //仅为示例,并非真实的接口地址

data: {

x: '',

y: ''

},

header: {

'content-type': 'application/json' // 默认值

},

success (res) {

console.log(res.data)

}

})

2.图片选择与微信拍照:

a.wx.chooseImage选择图片

概念: 从本地相册选择图片或使用相机拍照。

参数如下表:

属性

类型

默认值

是否必填

说明

支持版本

count

number

9

最多可以选择的图片张数


sizeType

Array.<string>

['original', 'compressed']

所选的图片的尺寸


sourceType

Array.<string>

['album', 'camera']

选择图片的来源


success

function


接口调用成功的回调函数


fail

function


接口调用失败的回调函数


complete

function


接口调用结束的回调函数(调用成功、失败都会执行)


示例代码如下:

wx.chooseImage({

count: 1,

sizeType: ['original', 'compressed'], //图片类型,原图和压缩图

sourceType: ['album', 'camera'], //图片来源,从相册选择还是拍照

success (res) {

// tempFilePath可以作为img标签的src属性显示图片

const tempFilePaths = res.tempFilePaths //返回选择的图片路径

}

})

3.文件的上传与下载:

a.文件上传wx.uploadFile:

概念:将本地资源上传到服务器。客户端发起一个 HTTPS POST 请求,其中 content-type 为 multipart/form-data

参数:

属性

类型

默认值

是否必填

说明

支持版本

url

string


开发者服务器地址


filePath

string


要上传文件资源的路径


name

string


文件对应的 key,开发者在服务端可以通过这个 key 获取文件的二进制内容


header

Object


HTTP 请求 Header,Header 中不能设置 Referer


formData

Object


HTTP 请求中其他额外的 form data


success

function


接口调用成功的回调函数


fail

function


接口调用失败的回调函数


complete

function


接口调用结束的回调函数(调用成功、失败都会执行)


示例代码:

wx.chooseImage({ //选择一张图片

success (res) {

const tempFilePaths = res.tempFilePaths //选择图片成功后的图片路径

wx.uploadFile({

url: 'https://example.weixin.qq.com/upload', //上传的服务器地址

filePath: tempFilePaths[0], //上传的文件为之前选择的图片

name: 'file', //文件名

formData: {

'user': 'test'

},

success (res){

const data = res.data //上传成功后做的操作

//do something

}

})

}

})


b.文件下载wx.downloadFile:

概念:下载文件资源到本地。客户端直接发起一个 HTTPS GET 请求,返回文件的本地临时路径。

参数:

属性

类型

默认值

是否必填

说明

支持版本

url

string


下载资源的 url


header

Object


HTTP 请求的 Header,Header 中不能设置 Referer


filePath

string


指定文件下载后存储的路径

>= 1.8.0

success

function


接口调用成功的回调函数


fail

function


接口调用失败的回调函数


complete

function


接口调用结束的回调函数(调用成功、失败都会执行)


示例代码:

wx.downloadFile({

url: 'https://example.com/audio/123', //仅为示例,并非真实的资源

success (res) {

// 只要服务器有响应数据,就会把响应内容写入文件并进入 success 回调,业务需要自行判断是否下载到了想要的内容

if (res.statusCode === 200) {

wx.playVoice({

filePath: res.tempFilePath

})

}

}

})


4.WebSocket:

a.什么是WebSocket

连接服务器,与服务器进行信息交互的API

b.使用WebSocket

1.连接服务器wx.connectSocket

示例代码:

wx.connectSocket({

url: 'wss://example.qq.com', //服务器地址,只有这个必填

data:{

x: '',

y: ''

},

header:{

'content-type': 'application/json'

},

protocols: ['protocol1'],

method:"GET"

})

2.向服务器发送信息wx.sendSocketMessage

示例代码:

wx.sendSocketMessage({

data:msg

})

3.关闭连接wx.closeSocket

示例代码:

wx.closeSocket()

c.监听WebSocket

1.wx.onSocketMessage监听WebSocket接收到服务器消息的事件

2.wx.onSocketOpen监听WebSocket 连接打开事件


5.音乐的播放和控制:

a.wx.getBackgroundAudioManager() 获取全局唯一的背景音频管理器。

b.BackgroundAudioManager实例:

backgroundAudioManager.title = '此时此刻' //音频标题(必填)

backgroundAudioManager.epname = '此时此刻' //专辑名

backgroundAudioManager.singer = '许巍' //歌手名

backgroundAudioManager.coverImgUrl = '...url' //封面图URL

backgroundAudioManager.src = '....url' //音乐URL


6.缓存数据:

a.wx.setStorage:将数据存储在本地缓存中指定的 key 中。数据存储上限为10MB

示例:

wx.setStorage({ //异步方式

key:"key",

data:"value"

})

try {

wx.setStorageSync('key', 'value') //同步方式

} catch (e) { }

b.wx.removeStorage:从本地缓存中移除指定Key

示例:

wx.removeStorage({ //异步方式

key: 'key',

})

try {

wx.removeStorageSync('key') //同步方式

} catch (e) {

// Do something when catch error

}

c.wx.getStorage:从本地缓存中异步获取指定 key 的内容

wx.getStorageSync:同步版本

d.wx.getStorageInfo:异步获取当前storage的相关信息

wx.getStorageInfoSync:同步版本

e.wx.clearStorage:清理本地数据缓存

wx.clearStorageSync:同步版本


7.获取当前位置:

a.wx.openLocation:使用微信内置地图查看位置

b.wx.getLocation:获取当前的地理位置

c.wx.chooseLocation:打开地图选择位置

d.综合应用代码:

wx.getLocation({

type: 'gcj02', //返回可以用于wx.openLocation的经纬度

success (res) {

const latitude = res.latitude //获取经纬度

const longitude = res.longitude

wx.openLocation({ //根据获取的经纬度查看位置

latitude,

longitude,

scale: 28 //缩放比例

})

}

})


8.交互:

a.wx.showToast:显示消息提示框

示例:

wx.showToast({

title: '成功', //提示内容

icon: 'success', //图标,有success和loading两种

duration: 2000 //提示的延迟时间

})

注意:wx.showLoading 和 wx.showToast 同时只能显示一个

wx.showToast 应与 wx.hideToast 配对使用

b.wx.showModal:显示模态对话框

示例:

wx.showModal({

title: '提示', //提示的标题

content: '这是一个模态弹窗', //提示的内容

success (res) {

if (res.confirm) {

console.log('用户点击确定')

} else if (res.cancel) {

console.log('用户点击取消')

}

}

})

c.wx.showActionSheet:显示操作菜单

示例:

wx.showActionSheet({

itemList: ['A', 'B', 'C'], //按钮的文字数组

success (res) {

console.log(res.tapIndex) //返回用户点击的按钮序号

},

fail (res) {

console.log(res.errMsg)

}

})


9.导航栏:

a.wx.setNavigationBarTitle:动态设置当前页面的标题

示例:

wx.setNavigationBarTitle({

title: '当前页面'

})

b.wx.showNavigationBarLoading:在当前页面显示导航条加载动画

c.wx.hideNavigationBarLoading:在当前页面隐藏导航条加载动画

d.wx.setNavigationBarColor:设置页面导航条颜色

示例:

wx.setNavigationBarColor({

frontColor: '#ffffff', //前景颜色值,包括按钮、标题、状态栏的颜色,仅支持 #ffffff 和 #000000

backgroundColor: '#ff0000', //背景颜色值,有效值为十六进制颜色

animation: { //动画效果

duration: 400, //动画变化时间

timingFunc: 'easeIn' //动画变化方式(以低速开始)

}

})


10.动画:

a.Animation wx.createAnimation(Object object):创建一个动画实例 animation。调用实例的方法来描述动画。最后通过动画实例的 export 方法导出动画数据传递给组件的 animation 属性。

b.示例代码:

<view animation="{{animationData}}" style="background:red;height:100rpx;width:100rpx"></view>

Page({

data: {

animationData: {}

},

onShow: function(){

var animation = wx.createAnimation({ //创建动画示例

duration: 1000, //动画持续时间

timingFunction: 'ease', //动画以低速开始,然后加快,在结束前变慢

})

this.animation = animation

animation.scale(2,2).rotate(45).step() //动画样式,缩放的同时旋转45度,step表示一组动画完成

this.setData({

animationData:animation.export()

})

相关推荐

Flutter——输入部件

上一节介绍了文本部件,用于显示文本。但是在我们进行日常软件开发过程中,经常是需要获取用户键入的内容,比如用户名、密码、性别、喜好等等。Flutter提供了丰富的部件来处理用户输入,本节将主要介绍以下...

flutter系列之:做一个图像滤镜

简介很多时候,我们需要一些特效功能,比如给图片做个滤镜什么的,如果是h5页面,那么我们可以很容易的通过css滤镜来实现这个功能。那么如果在flutter中,如果要实现这样的滤镜功能应该怎么处理呢?一起...

免费好用还高级!3个必须知道的设计网站,让你的PPT好看10倍

哈喽,大家早上好鸭~好久不见,我是三石,今天我又来进行PPT技巧分享啦~诶,这不前几天编辑部的萌萌就来找我约稿,说小叶子们对于神器网站的呼声很高,问我能不能写一篇文章汇总一下,我二话没说就答应了。常言...

flutter软件开发笔记08-容器使用方法

在Flutter3中,容器组件是用于布局、装饰或约束子组件的核心部件,能让程序更加美观,如何学习呢,能快速的应用起来,下面通过例子,来快速理解各种容器组件的使用方法。一程序界面二代码实现imp...

Tauri:下一代桌面应用开发框架?

大厂技术坚持周更精选好文本文为来自教育-智能学习-前端团队成员的文章,已授权ELab发布。智能学习前端团队自创立以来,团队专注于打破大众对教育的刻板印象,突破固有的教学思维,攻破各类...

Google移动开发平台Flutter发布 iOS和Android开发者神器

在昨晚的FlutterLive2018上,Google宣布Flutter1.0正式发布。这是一个基于Dart的移动开发平台,旨在帮助开发者在iOS和Android两个平台上...

Flutter如何内存优化

Flutter是一种流行的跨平台移动应用程序开发框架,它提供了一种高效的方式来构建美观、快速、可靠的应用程序。然而,随着应用程序规模的增加,内存管理成为了一个重要的问题。本文将探讨如何优化Flutte...

阿里卖家 Flutter for Web 工程实践

作者:马坤乐(坤吾)Flutter自2015年初次亮相以来,经过了多年的发展已经相当成熟,在阿里、美团、拼多多等互联网公司都有广泛的应用。在ICBU阿里卖家上90+%的新业务使用Flu...

Flutter——按钮

上一节介绍了输入组件,让我们了解了输入框、单选、多选、进度条等部件。为了响应用户的点击或触摸操作,就需要学习一种新的部件-按钮。Flutter中有多种类型的按钮,用于响应用户的点击或触摸操作。接下来...

Flutter vs React Native 性能测试结果

FluttervsReactNative性能测试结果:谁才是王者?大家好,我是猫哥。今天会去讲一下Flutter和ReactNative的性能比较的情况。首先说一下ReactNative猫哥...

定位Flutter内存问题很难么?

内存水位升高导致的稳定性问题严重影响app用户体验,所以开发者们非常关注Flutter的内存表现。随着Flutter业务越来越多,闲鱼也面临着oom导致的crash率提升的问题,下面我们结合项目中实际...

超详解析Flutter渲染引擎|业务想创新,不了解底层原理怎么行?

作者|万红波(远湖)出品|阿里巴巴新零售淘系技术部前言Flutter作为一个跨平台的应用框架,诞生之后,就被高度关注。它通过自绘UI,解决了之前RN和weex方案难以解决的多端一致性...

flutter软件开发笔记25-内置组件总结

以下是Flutter内置的核心UI组件分类及常用组件列表,方便你系统化学习和掌握:1.基础组件组件名说明Text显示文本,支持样式、换行和富文本(TextSpan)Icon显示Materi...

Flutter CarouselView 3.24版本的一个新组件

Flutter3.24带来了几个令人兴奋的新功能,其中最引人注目的是CarouselView小部件。这个小部件允许开发人员创建可滚动的、动态的项目列表,这些列表可以在进入和退出视图时调整大小,这对于...

详解Flutter如何用思源宋体炫出你的UI

如何实现使用思源宋体字体样式。首先,让我们来了解一下什么是资源素材管理。简单来说,它就是为了方便我们管理各种资源文件,比如图片、字体、音频等。在Flutter中,我们可以使用pubspec.yam...