微信小程序API是开发者在微信小程序中实现各种功能的重要工具。所有API都保存在小程序的全局对象wx中。通过调用这些API,开发者可以实现界面交互、网络请求、数据存储、用户授权等多种功能。
界面交互API主要用于实现小程序与用户的交互,如显示消息提示框、加载框、模态对话框等。
wx.showToast()方法。例如,显示一个成功提示框:wx.showToast({title: '成功', icon: 'success', duration: 2000})
            wx.showLoading()方法。需要主动调用wx.hideLoading()来关闭提示框:wx.showLoading({title: '加载中'})
            setTimeout(function(){wx.hideLoading()}, 2000)
            wx.showModal()方法。可以处理用户点击确定或取消的操作:wx.showModal({
                title: '提示',
                content: '这是一个模态弹窗',
                success(res) {
                    if (res.confirm) {
                        console.log('用户点击确定')
                    } else if (res.cancel) {
                        console.log('用户点击取消')
                    }
                }
            })
         
        网络请求API主要用于实现小程序与服务器之间的数据交互。
wx.request()方法。需要配置请求的URL、数据、头等参数:wx.request({
                url: '',
                data: {x: '', y: ''},
                header: {'content-type': 'application/json'},
                success(res) {
                    console.log(res.data)
                }
            })
            wx.downloadFile()方法。可以下载文件到本地并获取临时路径:wx.downloadFile({
                url: '',
                success(res) {
                    if (res.statusCode === 200) {
                        wx.playVoice({filePath: res.tempFilePath})
                    }
                }
            })
            wx.uploadFile()方法。可以将本地文件上传到服务器:wx.uploadFile({
                url: '',
                filePath: tempFilePaths[0],
                name: 'file',
                formData: {'user': 'test'},
                success(res) {
                    const data = res.data
                    // do something
                }
            })
        用户信息API主要用于获取用户的个人信息,以便进行用户授权和个性化设置。
wx.getUserProfile()方法。需要用户授权后才能获取到用户的昵称、头像等信息:wx.getUserProfile({
                desc: '展示用户信息',
                success: (res) => {
                    console.log(res)
                }
            })
        除了上述几类API外,微信小程序还提供了许多其他常用的API,如获取系统信息、发起支付、获取位置等。
wx.getSystemInfo()方法。可以获取到设备的型号、屏幕宽度、高度等信息:wx.getSystemInfo({
                success(res) {
                    console.log(res.model)
                    console.log(res.pixelRatio)
                    console.log(res.windowWidth)
                    console.log(res.windowHeight)
                }
            })
            wx.requestPayment()方法。需要配置支付的相关参数,如时间戳、签名等:wx.requestPayment({
                timeStamp: '',
                nonceStr: '',
                package: '',
                signType: 'MD5',
                paySign: '',
                success(res) {},
                fail(res) {}
            })
            wx.getLocation()方法。可以获取到用户的当前位置信息,如经纬度、速度等:wx.getLocation({
                type: 'wgs84',
                success(res) {
                    const latitude = res.latitude
                    const longitude = res.longitude
                    const speed = res.speed
                    const accuracy = res.accuracy
                }
            })
         
        在微信小程序中,自定义组件是一种可以复用的UI结构。开发者可以通过创建自定义组件来封装一些常用的功能,并在需要的地方进行调用。
在自定义组件中,同样可以调用小程序提供的API来实现各种功能。例如,在自定义组件的JS文件中,可以使用wx.request()方法来发起网络请求,获取数据并更新组件的UI。
微信小程序API是开发者实现小程序功能的重要工具。通过掌握各类API的使用方法,开发者可以轻松地实现界面交互、网络请求、用户授权等多种功能。同时,自定义组件的引入也为开发者提供了更多的复用性和灵活性。