首页 > 其他分享 >MiniProgram

MiniProgram

时间:2025-01-16 09:33:26浏览次数:1  
标签:miniProgram string automator await launch MiniProgram Promise

MiniProgram

MiniProgram 模块提供了控制小程序的方法。

方法

miniProgram.pageStack

获取小程序页面堆栈。

miniProgram.pageStack(): Promise<Page[]> 

示例代码:

automator.launch().then(async miniProgram => {
  const pageStack = await miniProgram.pageStack()
  console.log(pageStack.length) // 当前页面栈数量
})

miniProgram.navigateTo

保留当前页面,跳转到应用内的某个页面,同 wx.navigateTo

miniProgram.navigateTo(url: string): Promise<Page>

参数说明

字段 类型 必填 默认值 说明
url string - 需要跳转的应用内非 tabBar 的页面的路径

示例代码:

automator.launch().then(async miniProgram => {
  const page = await miniProgram.navigateTo('/page/component/index')
  console.log(page.path) // -> 'page/component/index'
})

miniProgram.redirectTo

关闭当前页面,跳转到应用内的某个页面,同 wx.redirectTo

miniProgram.redirectTo(url: string): Promise<Page>

参数说明

字段 类型 必填 默认值 说明
url string - 需要跳转的应用内非 tabBar 的页面的路径

miniProgram.navigateBack

关闭当前页面,返回上一页面或多级页面,同 wx.navigateBack

miniProgram.navigateBack(): Promise<Page>

miniProgram.reLaunch

关闭所有页面,打开到应用内的某个页面,同 wx.reLaunch

miniProgram.reLaunch(url: string): Promise<Page>

参数说明

字段 类型 必填 默认值 说明
url string - 需要跳转的应用内页面路径

miniProgram.switchTab

跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面,同 wx.switchTab

miniProgram.switchTab(url: string): Promise<Page>

参数说明

字段 类型 必填 默认值 说明
url string - 需要跳转的 tabBar 页面的路径

miniProgram.currentPage

获取当前页面。

miniProgram.currentPage(): Promise<Page>

miniProgram.systemInfo

获取系统信息,同 wx.getSystemInfo

miniProgram.systemInfo(): Promise<Object>

示例代码:

automator.launch().then(async miniProgram => {
  const systemInfo = await miniProgram.systemInfo()
  if (systemInfo.platform === 'devtools') {
    // Do something
  }
})

miniProgram.callWxMethod

调用 wx 对象上的指定方法。

miniProgram.callWxMethod(method: string, ...args: any[]): Promise<any>

参数说明

字段 类型 必填 默认值 说明
method string - 需要调用的方法名
...args array - 方法参数

调用异步方法时无需传入 success 及 fail 回调函数。

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.callWxMethod('setStorage', {
    key: 'test',
    data: 'test'
  })
  const { data } = await miniProgram.callWxMethod('getStorageSync', 'test')
  console.log(data) // -> 'test'
})

miniProgram.callPluginWxMethod

基础库 2.19.3 开始支持。

调用插件 wx 对象上的指定方法,用法同 miniProgram.callWxMethod。

miniProgram.callWxMethod(pluginId: string, method: string, ...args: any[]): Promise<any>

miniProgram.mockWxMethod

传入函数功能 automator 0.9.0,基础库 2.9.5 开始支持。

覆盖 wx 对象上指定方法的调用结果。

利用该接口,你可以很方便地直接指定 wx.chooseLocation 等调用系统组件的返回结果。

miniProgram.mockWxMethod(method: string, result: any): Promise<void>
miniProgram.mockWxMethod(method: string, fn: Function | string, ...args: any[]): Promise<void>

参数说明

字段 类型 必填 默认值 说明
method string - 需要覆盖的方法名
result any - 指定调用结果
字段 类型 必填 默认值 说明
method string - 需要覆盖的方法名
fn Function string - 处理返回函数
...args array - 传入参数

fn 同 miniProgram.evaluate 的 appFunction 参数一样,无法使用闭包来引用外部变量。此外,你还可以在方法内使用 this.origin 来调用原始方法。

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.mockWxMethod('showModal', {
    confirm: true,
    cancel: false
  })

  await miniProgram.mockWxMethod(
    'getStorageSync',
    function(key, defVal) {
      if (key === 'name') return 'redhoodsu'
      if (key === 'sex') return 'male'
      return defVal
    },
    'unknown',
  )
  // 调用 wx.getStorageSync('name') 返回 'redhoodsu'

  // 更改 getSystemInfo 中的 platform 字段
  await miniProgram.mockWxMethod(
    'getSystemInfo',
    function(obj, platform) {
      return new Promise(resolve => {
        // origin 指向原始方法
        this.origin({
          success(res) {
            res.platform = platform
            resolve(res)
          },
        })
      })
    },
    'test',
  )
})

miniProgram.mockPluginWxMethod

基础库 2.19.3 开始支持。

覆盖插件 wx 对象上指定方法的调用结果,用法同 miniProgram.mockWxMethod。

miniProgram.mockWxMethod(pluginId: string, method: string, result: any): Promise<void>
miniProgram.mockWxMethod(pluginId: string, method: string, fn: Function | string, ...args: any[]): Promise<void>

miniProgram.restoreWxMethod

重置 wx 指定方法,消除 mockWxMethod 调用的影响。

miniProgram.restoreWxMethod(method: string): Promise<void>

参数说明

字段 类型 必填 默认值 说明
method string - 需要覆盖的方法名

示例代码:

automator.launch().then(async miniProgram => {
  console.log(await miniProgram.callWxMethod('getStorageSync', 'test')) // -> ''
  await miniProgram.mockWxMethod('getStorageSync', 'mockValue')
  console.log(await miniProgram.callWxMethod('getStorageSync', 'test')) // -> 'mockValue'
  await miniProgram.restoreWxMethod('getStorageSync')
  console.log(await miniProgram.callWxMethod('getStorageSync', 'test')) // -> ''
})

miniProgram.restorePluginWxMethod

基础库 2.19.3 开始支持。

重置插件 wx 指定方法,消除 mockPluginWxMethod 调用的影响,用法同 miniProgram.restoreWxMethod。

miniProgram.restoreWxMethod(pluginId: string, method: string): Promise<void>

miniProgram.evaluate

往 AppService 注入代码片段并返回执行结果。

miniProgram.evaluate(appFunction: Function | string, ...args: any[]): Promise<any>

参数说明

字段 类型 必填 默认值 说明
appFunction Function string - 代码片段
...args array - 执行时传入参数

appFunction 最终会被序列化传递到开发者工具,因此你无法在函数中利用闭包来引用外部变量。也就是说,传递 function () {} 函数事实上等同于传递其字符串。

示例代码:

automator.launch().then(async miniProgram => {
  let systemInfo = await miniProgram.evaluate(() => {
    return new Promise(resolve => {
      wx.getSystemInfo({
        success(result) {
          resolve(result)
        }
      })
    })
  })
  systemInfo = await miniProgram.evaluate(() => {
    return wx.getSystemInfoSync()
  })
  console.log(systemInfo)
  await miniProgram.evaluate(key => {
    wx.setStorageSync(key, 'test')
  }, 'test')
  const hasLogin = await miniProgram.evaluate(() => getApp().globalData.hasLogin)
  console.log(hasLogin)
})

miniProgram.pageScrollTo

将页面滚动到目标位置,同 wx.pageScrollTo

miniProgram.pageScrollTo(scrollTop: number): Promise<void>

参数说明

字段 类型 必填 默认值 说明
scrollTop number - 滚动到页面的目标位置,单位 px

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.pageScrollTo(50)
})

miniProgram.screenshot

automator 0.9.0,基础库 2.9.5,开发者工具 1.02.2001082 开始支持

对当前页面截图,目前只有开发者工具模拟器支持,客户端无法使用。

miniProgram.screenshot(options?: Object): Promise<string | void>

参数说明

字段 类型 必填 默认值 说明
options Object - 截图选项

如果不传 options,该方法返回图片数据的 base64 编码。

options 字段定义如下:

字段 类型 必填 默认值 说明
path string - 图片保存路径
automator.launch().then(async miniProgram => {
  await miniProgram.screenshot({
    path: 'screenshot.png'
  })
})

miniProgram.exposeFunction

在 AppService 全局暴露方法,供小程序侧调用测试脚本中的方法。

miniProgram.exposeFunction(name: string, bindingFunction: Function): Promise<void>

参数说明

字段 类型 必填 默认值 说明
name string - 全局方法名
bindingFunction Function - 脚本方法

你可以利用该方法来监听事件,不支持在小程序侧获取调用结果。

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.exposeFunction('onAppShow', options => {
    // Do something... 
  })
  await miniProgram.evaluate(function() {
    wx.onAppShow(function(options) {
      onAppShow(options)
    })
  })
})

miniProgram.testAccounts

automator 0.9.0,开发者工具 1.02.2002272 开始支持

获取多账号调试中已添加的用户列表。

miniProgram.testAccounts(): Promise<Account[]>

Account 字段定义如下:

字段 类型 说明
nickName string 用户昵称
openid string 账号 openid

示例代码:

automator.launch().then(async miniProgram => {
  const testAccounts = await miniProgram.testAccounts()
  for (let i = 0, len = testAccounts.length; i < len; i++) {
    const miniProgram = await automator.launch({
      projectPath: 'path/to/project',
      account: testAccounts[i].openid
    })
    // 控制多个用户登录的不同小程序
  }
})

miniProgram.stopAudits

automator 0.10.0,开发者工具 1.04.2006242 开始支持

停止体验评分并获取报告。

miniProgram.stopAudits(options?: Object): Promise<Object>

参数说明

字段 类型 必填 默认值 说明
options Object - 选项

options 字段定义如下:

字段 类型 必填 默认值 说明
path string - 报告保存路径

需要开启自动运行体验评分选项。

automator.launch({
  projectConfig: {
    setting: {
      autoAudits: true,
    },
  },
}).then(async miniProgram => {
  const data = await miniProgram.stopAudits({
    path: 'report.html'
  })
  console.log(data) // 体验评分报告数据
})

miniProgram.getTicket

获取开发者工具当前的登录票据。

确保工具安全设置中已开启允许获取工具登录票据功能。

miniProgram.getTicket(): Promise<Object>

返回值说明

字段 类型 说明
ticket string 登录票据
expiredTime number 票据过期时间

示例代码:

automator.launch().then(async miniProgram => {
  const result = await miniProgram.getTicket()
  console.log(result.ticket)
})

miniProgram.setTicket

设置开发者工具登录票据,可在工具运行测试期间更新失效的登录票据。

miniProgram.setTicket(ticket: string): Promise<void>

参数说明

字段 类型 必填 默认值 说明
ticket string - 登录票据

示例代码:

// ticket 从已登录的开发者工具获取
automator.launch({
  ticket,
}).then(async miniProgram => {
  // 如果初始票据已失效,获取新票据后通过 setTicket 更新
  await miniProgram.setTicket(ticket)
})

miniProgram.refreshTicket

刷新开发者工具登录票据,可以使票据过期时间重置为两小时。

miniProgram.refreshTicket(): Promise<void>

刷新票据后原有的票据即使过期时间未到也会过期。

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.refreshTicket()
})

miniProgram.remote

开启工具真机调试功能。

miniProgram.remote(auto?: boolean): Promise<void>

参数说明

字段 类型 必填 默认值 说明
auto boolean false 是否自动真机调试

调用后脚本会启动工具真机调试功能,并且在控制台上打印二维码,然后你需要使用真机扫码连接使自动化脚本继续跑下去。

auto 为 true 时,真机上会自动调起小程序,无需扫码,仅支持微信 7.0.6(安卓)、6.6.7(iOS)及以上版本。有关真机自动化相关内容,请点此查看。

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.remote()
  // 扫码连接成功后在真机上执行自动化脚本
})

miniProgram.disconnect

断开与小程序运行时的连接。

miniProgram.disconnect(): void

示例代码:

automator.launch().then(async miniProgram => {
  miniProgram.disconnect()
})

miniProgram.close

断开与小程序运行时的连接并关闭项目窗口。

miniProgram.close(): Promise<void>

示例代码:

automator.launch().then(async miniProgram => {
  await miniProgram.close()
})

事件

console

日志打印时触发。

传递一个 msg 参数,其字段如下:

字段 类型 说明
type string 日志类型,log、info 等
args array 日志内容

示例代码:

automator.launch().then(async miniProgram => {
  miniProgram.on('console', msg => {
    console.log(msg.type, msg.args)
  })
})

exception

页面 JS 出错时触发。

传递一个 error 参数,其字段如下:

字段 类型 说明
message string 错误信息
stack string 错误堆栈

示例代码:

automator.launch().then(async miniProgram => {
  miniProgram.on('exception', err => {
    console.log(err.message, err.stack)
  })
})

标签:miniProgram,string,automator,await,launch,MiniProgram,Promise
From: https://www.cnblogs.com/AtlasLapetos/p/18641902

相关文章

  • miniprogram-ci
    概述miniprogram-ci是从微信开发者工具中抽离的关于小程序/小游戏项目代码的编译模块。开发者可不打开小程序开发者工具,独立使用miniprogram-ci进行小程序代码的上传、预览等操作。miniprogram-ci从1.0.28开始支持第三方平台开发的上传和预览,调用方式与普通开发模式无异......
  • wx.checkIsAddedToMyMiniProgram
    wx.checkIsAddedToMyMiniProgram(Objectobject)基础库2.29.1开始支持,低版本需做兼容处理。以Promise风格调用:不支持小程序插件:不支持微信Windows版:支持微信Mac版:支持微信鸿蒙OS版:支持功能描述检查小程序是否被添加至「我的小程序」参数Objectobject......
  • 微信小程序中使用miniprogram-sm-crypto实现SM4加密攻略
    在微信小程序开发过程中,数据安全至关重要。本文将为大家介绍如何在微信小程序中使用miniprogram-sm-crypto插件进行SM4加密,确保数据传输的安全性。一、SM4加密简介SM4是一种对称加密算法,由国家密码管理局发布,适用于商密领域。它的密钥长度为128位,分组长度为128位,加密过程采用......
  • 利用miniprogram-ci工具实现一键上传微信小程序代码
    本文由ChatMoney团队出品利用miniprogram-ci工具在后台实现一键上传微信小程序代码,避免了微信开发者工具的繁琐。一、部署node环境我用的是宝塔,可以直接在宝塔上安装Node.js版本管理器二、安装miniprogram-cinpminstallminiprogram-ci--save安装在指定文件夹里,这个......
  • Jenkins +miniprogram-ci 构建 发布、预览微信小程序
    #!/bin/bash-lsed-i"s/currentEnvironment='.*'/currentEnvironment='$DEPLOY_ENV'/g"'/var/lib/jenkins/workspace/nfc_recharge/utils/config.js'rm-rfqrcode*.jpgyarnyarnwxcitype=$actionappid=$appidversion......
  • 关于微信小程序VM22:2 (in promise) MiniProgramError {“errMsg“:“hideLoading:fai
    参考地址:https://blog.csdn.net/qq_41227106/article/details/108465104 出现错误的原因如下1、是微信小程序2、把请求接口统一封装,开始请求接口时showLoading,请求接口后hideLoading3、一个页面同时请求多个接口,由于请求是异步的,很有可能上一个开启了showLoading还没请求完......
  • Jenkins +miniprogram-ci 构建 发布、预览微信小程序
           #!/bin/bash-lrm-rfqrcode*.jpgyarnyarnwxcitype=$actionappid=$appidversion=$versiondesc=$descbuildId=${BUILD_ID}#计算过期时间,并将过期时间写进自定义环境变量#计算过期时间,并将过期时间写进自定义环境变量now=`date'+%Y-%m-%d%H......
  • 浅析微信小程序自动化部署miniprogram-ci介绍及实际使用
    一、miniprogram-ci介绍1、miniprogram-ci简介miniprogram-ci是从微信开发者工具中抽离的关于小程序/小游戏项目代码的编译模块。开发者可不打开小程序开发者工具,独立使用miniprogram-ci进行小程序代码的上传、预览等操作。文档:https://www.npmjs.com/package/min......
  • 微信小程序嵌入H5,从H5获取数据返回小程序页面(wx.miniProgram.postMessage)
    https://www.jianshu.com/p/469d89273a3f 需求:微信小程序使用web-view组件嵌入H5链接,从H5页面中获取某些数据在微信小程序页面中进行处理。微信文档中有web—view......
  • 微信小程序跳转到另一个小程序 wx.navigateToMiniProgram 方法,调试
    wx.navigateToMiniProgram(Objectobject)需要页面权限:小程序不能在插件页面中调用该接口,插件也不能在小程序页面中调用该接口打开另一个小程序wx.navigateToMiniPro......