微信小程序的常见面试题?

前言

随便打开一个招聘网站,你会发现市场对于小程序的需求还是蛮高的,有些公司可能就只需要写小程序的前端人员。故此,有了这样一篇小程序面试题的总结。

整理了关于小程序面试常问的一些面试题,分享给大家。

1、简单谈谈微信小程序

在结构和样式方面,小程序提供了一些常用的标签与控件,比如:

view,小程序主要的布局元素,类似于html标签的div,你也完全可以像控制div那样去控制view。

scroll-view,你要滚动内容的话,没必要用view去做overflow,scroll-view提供了更为强大的功能,通过参数的调整,你可以控制滚动方向,触发的事件等等

配置文件app.json平级的还有一个app.js文件,是小程序的脚本代码。我们可以在这个文件中监听并处理小程序的生命周期函数、声明全局变量,在每个page目录里的js做当前页面的业务操作。但是小程序的页面的脚本逻辑是在JsCore中运行,JsCore是一个没有窗口对象的环境,所以不能在脚本中使用window,也无法在脚本中操作组件,所以我们常用的zepto/jquery 等类库也是无法使用的。

另一个app.wxss文件,这个是全局的样式,所有的页面都会调用到,每个项目目录下面的wxss是局部样式文件,不会和其他目录产生污染,可以放心使用样式名

他提供的WXSS(WeiXin Style Sheets)是一套样式语言,具有 CSS 大部分特性,可以看作一套简化版的css。

同时为了更适合开发微信小程序,还对 CSS 进行了扩充以及修改,直接帮我们把适配的一部分工作都做了,比如他的rpx(responsive pixel),可以根据屏幕宽度进行自适应,规定屏幕宽为750rpx。如在 iPhone6 上,屏幕宽度为375px,共有750个物理像素,则750rpx = 375px = 750物理像素,1rpx = 0.5px = 1物理像素。

在调用微信生态系统功能时,微信小程序提供了相应的api,比如你要修改一个头像,可以使用wx.chooseImage等 。

2、小程序的原生组件有哪些?

以微信小程序为例,可以分成容器组件、基础组件、表单组件、媒体组件、开放能力组件等。

3、小程序的安卓版和ios版是怎么开发出来?

小程序开发基于html、css、javascript,与web开发一样具有跨平台特性,一次开发即可在安卓和iOS等平台访问。但与普通web开发不同,小程序运行环境并不是浏览器,而是依附于各自的软件App。如微信小程序必须在微信中访问,支付宝小程序必须在支付宝中访问等,小程序的开发流程也有所不同,需要经过申请小程序帐号、安装小程序开发者工具、配置项目、开发、调试、上线发布等过程方可完成。

4、uni-app弹窗被覆盖怎么解决?

如果弹窗被别的内容覆盖,且设置很大的z-index也无法解决,这种情况多半是被一些如mapvideotextareacanvas等原生组件遮盖,因为原生组件层级高于前端组件,我们可以使用cover-view组件解决。

5、小程序生命周期

onReady 生命周期函数--监听页面初次渲染完成

onShow 生命周期函数--监听页面显示

onHide 生命周期函数--监听页面隐藏

onUnload 生命周期函数--监听页面卸载

onPullDownRefresh 页面相关事件处理函数--监听用户下拉动作

onReachBottom 页面上拉触底事件的处理函数

onShareAppMessage 用户点击右上角转发

onPageScroll 页面滚动触发事件的处理函数

onTabItemTap 当前是 tab 页时,点击 tab 时触发

6、小程序路由跳转

(1)通过组件navigator跳转,设置url属性指定跳转的路径,设置open-type属性指定跳转的类型(可选),open-type的属性有 redirect, switchTab, navigateBack

(2)通过api跳转,wx.navigateTo() , wx.navigateBack(), wx.redirectTo() , wx.switchTab(), wx.reLanch()

7、小程序的兼容问题有哪些?

遇到的如下:

  • 1,ios下的zIndex层级问题,主要发生在iphone7和iphoneX下 绝对定位必须有一个共同的父元素。
  • 2,左右边框不生效 当边框的宽度设置为奇数的时候,可能会不生效 解决方法:将宽度设置为偶数的时候,在ios下就可以解决
  • 3,还有尽量不要用margin-bottom ,当元素是在整个页面的最底部的时候,在ios下可能margin-bottom会失效,所以建议,都使用padding-bottom

new Date跨平台兼容性问题

在Andriod使用new Date(“2018-05-30 00:00:00”)木有问题,但是在ios下面识别不出来。

因为IOS下面不能识别这种格式,需要用2018/05/30 00:00:00格式。可以使用正则表达式对做字符串替换,将短横替换为斜杠。var iosDate= date.replace(/-/g, '/');。

wx.getUserInfo()接口更改问题

微信小程序最近被吐槽最多的一个更改,就是用户使用wx.getUserInfo(开发和体验版)时不会弹出授权,正式版不受影响。现在授权方式是需要引导用户点击一个授权按钮,然后再弹出授权。

8、小程序框架都掌握哪一些?uniapp都会哪一些平时开发遇到的困难

  • Taro
  • uni-app
  • WeUI
  • mpvue
  • iView Weapp

开发uni-app遇到的坑

上传图片

小程序时必须要写header:{“Content-Type”: “multipart/form-data”}, h5是必须省略

uni-app h5 端的ios图片不能加载问题

uni-app h5端 ios只能加载https的图片

uni-app 使用deep 穿透微信小程序生效 h5无作用

需要在methods同级下加一个 :

options: { styleIsolation: ‘shared’ },

uni-app post请求如何传递数组 参数

在开发中我们接口上传图片是post请求 无法传递一个数组 解决方法如下

我们可以把数据转换成字符串 然后拼接到请求地址后后面

拼接字符串格式:image[]=arr[0]&image[]=arr[1]

imgURlClick(imgArr){ 
    return '?images[]='+imgArr.join('&images[]=') 
} 

9、小程序怎么获取手机号?

准备一个button组件, 将 button组件 open-type的值设置为 getPhoneNumber,当用户点击并同意之后,可以通过 bindgetphonenumber事件回调获取到动态令牌code;

<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button> 
Page({ 
  getPhoneNumber (e) { 
    console.log(e.detail.code) 
  } 
}) 

接着把code传到开发者后台,并在开发者后台调用微信后台提供的

phonenumber.getPhoneNumber接口,消费code来换取用户手机号。每个code

有效期为5分钟,且只能消费一次。

getPhoneNumber: function (e) { 
    var that = this; 
    console.log(e.detail.errMsg == "getPhoneNumber:ok"); 
    if (e.detail.errMsg == "getPhoneNumber:ok") { 
      wx.request({ 
        url: 'http://localhost/index/users/decodePhone', 
        data: { 
          encryptedData: e.detail.encryptedData, 
          iv: e.detail.iv, 
          sessionKey: that.data.session_key, 
          uid: "", 
        }, 
        method: "post", 
        success: function (res) { 
          console.log(res); 
        } 
      }) 
    } 
 } 

注:getPhoneNumber 返回的 code 与 wx.login 返回的 code 作用是不一样的,不能混用.

注:从基础库 2.21.2 开始,对获取手机号的接口进行了安全升级, 需要用户主动触发才能发起获取手机号接口,所以该功能不由 API 来调用,需用 button 组件的点击来触发。另外,新版本接口不再需要提前调用wx.login进行登录。

10、小程序的登录流程

登陆流程:

首次登录

  • 调用小程序api接口 wx.login() 获取 临时登录凭证code ,这个code是有过期时间的.
  • 将这个code回传到开发者服务器(就是请求开发者服务器的登录接口,通过凭证进而换取用户登录态信息,包括用户的唯一标识(openid)及本次登录的会话密钥(session_key)等)
  • 拿到开发者服务器传回来的会话密钥(session_key)之后,前端需要保存起来.
wx.setStorageSync('sessionKey', 'value') 

再次登录的时候,就要判断存储的session_key是否过期了

  • 获取缓存中的session_key,wx.getStorageSync('sessionKey')
  • 如果缓存中存在session_key,那么调用小程序api接口wx.checkSession()来判断登录态是否过期,回调成功说明当前 session_key 未过期,回调失败说明 session_key 已过期。登录态过期后前端需要再调用 wx.login()获取新的用户的code,然后再向开发者服务器发起登录请求.
  • 一般在项目开发,开发者服务器也会对用户的登录态做过期限制,所以这时在判断完微信服务器中登录态如果没有过期之后还要判断开发者服务器的登录态是否过期。(请求开发者服务器给定的接口进行请求判断就好)

参考官网: 小程序登陆流程 登陆态过期检测

11、小程序如果版本更新了怎么通知用户?

当小程序发布新的版本后,用户如果之前访问过该小程序,通过已打开的小程序进入(未手动删除),则会弹出提示,提醒用户更新新的版本。用户点击确定就可以自动重启更新,点击取消则关闭弹窗,不再更新.

核心步骤:

  • 打开小程序, 检查小程序是否有新版本发布
updateManager.onCheckForUpdate(function (res) {}) 

小程序有新版本,则静默下载新版本,做好更新准备

updateManager.onUpdateReady(function () {}) 

新的版本已经下载好,调用 applyUpdate应用新版本并重启小程序

updateManager.applyUpdate() 

微信开发者工具上可以通过「编译模式」下的「下次编译模拟更新」开关来调试.

点击编译模式设置下拉列表,然后点击“添加编译模式”,在自定义编译条件弹窗界面,点击下次编译时模拟更新,然后点击确定,重新编译就可以了.

注: 需要注意的是,这种方式模拟更新一次之后就失效了,后边再测试仍需要对这种编译模式进行重新设置才可以.

  • 核心代码如下:
App({ 
  onLaunch: function(options) { 
    this.autoUpdate() 
  }, 
  autoUpdate:function(){ 
    var self=this 
    // 获取小程序更新机制兼容 
    if (wx.canIUse('getUpdateManager')) { 
      const updateManager = wx.getUpdateManager() 
      //1. 检查小程序是否有新版本发布 
      updateManager.onCheckForUpdate(function (res) { 
        // 请求完新版本信息的回调 
        if (res.hasUpdate) { 
          //2. 小程序有新版本,则静默下载新版本,做好更新准备 
          updateManager.onUpdateReady(function () { 
            wx.showModal({ 
              title: '更新提示', 
              content: '新版本已经准备好,是否重启应用?', 
              success: function (res) { 
                if (res.confirm) { 
                  //3. 新的版本已经下载好,调用 applyUpdate 应用新版本并重启 
                  updateManager.applyUpdate() 
                } else if (res.cancel) { 
                  //不应用 
                } 
              } 
            }) 
          }) 
          updateManager.onUpdateFailed(function () { 
            // 新的版本下载失败 
            wx.showModal({ 
              title: '已经有新版本了哟~', 
              content: '新版本已经上线啦~,请您删除当前小程序,重新搜索打开哟~', 
            }) 
          }) 
        } 
      }) 
    } else { 
      // 如果希望用户在最新版本的客户端上体验您的小程序,可以这样子提示 
      wx.showModal({ 
        title: '提示', 
        content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。' 
      }) 
    } 
  } 
}) 

12、小程序嵌入H5页面怎么做?

解决方式 :web-view

webview 指向网页的链接。可打开关联的公众号的文章,其它网页需登录小程序管理后台配置业务域名。

具体实现步骤:

  • 登陆小程序管理后台, 配置服务器域名( h5页面所在的域名 )
  • 在小程序里面嵌入h5
  • 在小程序里面定义一个你想要的H5入口
<navigator url="/page/navigate/navigate" hover-class="navigator-hover">跳转到新页面</navigator> 
  • 新建一个页面,放置 webview , src指向h5网页的链接.
<web-view src="{{url}}" bindmessage="getMessage"></web-view> </block> 

注: 实际开发中在h5页面中有可能需要向小程序发送消息, 实现h5页面和小程序页面的通信

需要使用postMessage向小程序发送消息, 在h5中postMessage 注意,key必须叫做data,否则取不到。

13、小程序的生命周期函数有哪些?分别有什么作用?

小程序的生命周期函数大体分为三类:

  • 小程序应用的生命周期
属性说明
onLaunch监听小程序初始化, 全局只触发一次
onShow监听小程序启动或切前台。
onHide监听小程序切后台。

参考官网: 应用的生命周期

  • 小程序页面的生命周期
属性说明
onLoad监听页面加载, 获取其他页面传过来的参数, 发起网络请求
onShow监听页面显示
onReady监听页面初次渲染完成
onHide监听页面隐藏
onUnload监听页面卸载

参考官网: 页面的生命周期

  • 小程序组件的生命周期
定义段描述
created在组件实例刚刚被创建时执行,注意此时不能调用 setData )
attached在组件实例进入页面节点树时执行)
ready在组件布局完成后执行)
moved在组件实例被移动到节点树另一个位置时执行)
detached在组件实例被从页面节点树移除时执行)

以上就是关于小程序的面试题,希望能帮带大家。欢迎大家持续关注哟!

  • 25
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Uniapp 是一个跨平台的开发框架,可以在不同的平台上实现一次编码,多端部署,非常适合开发微信小程序。以下是 Uniapp 微信小程序面试题的答案: 1. Uniapp 是什么? Uniapp 是一个跨平台的开发框架,可以基于 Vue.js 做开发,实现一次编码多端部署,包括微信小程序、H5、APP(安卓和 IOS)、快应用等。 2. 与传统微信小程序开发的区别是什么? 与传统微信小程序开发相比,Uniapp 开发更加高效,可以大大减少开发时间,同时也可以让开发者更加便捷地实现一次编码多端部署。 3. Uniapp 微信小程序如何实现多端适配? Uniapp 可以使用自动适配方案,在不同机型上自动调整组件大小和布局。如果需要自定义适配方案,可以根据不同平台的 CSS 尺寸单位和样式特性定义不同的样式来实现多端适配。 4. 如何添加微信小程序原生组件? 可以在 Uniapp 项目中使用相应的组件,然后在微信小程序中进行适配。如果需要使用微信小程序原生组件,可以使用插件的形式将原生组件导入 Uniapp 项目中使用。 5. 如何进行微信小程序支付? 可以使用 uni.request 接口向自己服务端请求支付的相关参数,然后调用 uni.requestPayment 接口发起支付请求,支付成功后进行相应的处理。在开发过程中需要注意安全性和用户体验,避免出现支付问题。 总之,Uniapp 微信小程序的开发让开发者更加容易实现一次编码多端部署,提高开发效率,也让用户体验更加顺畅。在开发过程中需要根据不同的需求和平台特性进行适配,保证产品的质量和用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋の本名

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值