微信小程序常见面试题

这篇具有很好参考价值的文章主要介绍了微信小程序常见面试题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、小程序有几个文件

  • WXML:是框架设计的一套标签语言,结合基础组件、事件系统,可以构建出页面的结构;
  • WXSS: 用于描述 WXML 的组件样式;
  • js: 逻辑处理;
  • json:小程序页面配置。

2、微信小程序与 H5 的区别

  • 运行环境:小程序的运行环境是微信客户端,H5 是浏览器。
  • 开发成本:小程序只在微信中运行,所以不用再去顾虑浏览器兼容性;H5 需要考虑。
  • 用户体验:小程序依然基于 APP 端去实现,在使用时更流畅。
  • 权限获取:小程序相比于 H5 能获得更多的系统权限,比如网络通信状态、数据缓存能力等;
  • 上线发布:小程序上线发布前要上传项目给微信官方审核,H5 无需通过官方审核。

3、简述微信小程序原理

  • 微信小程序本质就是一个单页面应用,采用 JavaScript、WXML、WXSS 进行开发;
  • 小程序使用数据驱动的架构模式,UI 和数据是分离的,通过对数据的更改来实现页面更新;
  • 小程序分为 webview 和 appService 两部分。其中 webview 用来展现 UI ,appService 用来处理业务逻辑。它们在两个进程中运行,这两个线程的通信会经由微信客户端,逻辑层发送网络请求也经由微信客户端转发。

    小程序面试题,微信小程序,微信小程序,小程序

4、小程序 WXSS 与 CSS 的区别

  • 新增尺寸单位为 rpx, rpx 是响应式像素,可以根据屏幕宽度进行自适应;
  • 小程序样式使用 @import 引入外联样式文件;
  • wxss 中不能使用本地图片;
  • wxss 仅支持部分 css 选择器:.class、#id、element、选择器分组(element, element)、::after、::before。

5、微信小程序与 vue 区别

  • 生命周期不一样,小程序生命周期比较简单;
  • 小程序数据绑定需要使用 {{ }},vue 则是使用 v-bind 来绑定;
  • 小程序使用 bindtap(bind+event) 绑定事件,vue 使用 v-on:event 绑定事件;
  • 小程序使用 wx-if 和 hidden 控制元素的显示和隐藏,vue 则使用 v-if 和 v-show 来控制;
  • 小程序列表渲染使用 wx:for="{{array}}",vue 使用 v-for="item in array";
  • 小程序条件渲染使用 wx:if="{{condition}}",vue 使用 v-if="condition";
  • 小程序使用 <block> 元素来渲染一个包含多节点的结构块,vue 使用 <template> 元素;
  • 小程序使用 this.setData({ key :value }) 来更新绑定数据。vue 使用 this.data.key = value。

6、微信小程序 Page 的生命周期有哪些

  • onLoad:页面加载时触发。一个页面只会调用一次,可在 onLoad 的参数中获取打开当前页面路径中的参数;
  • onShow:页面显示或切入前台时触发;
  • onReady:页面初次渲染完成时触发。一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互;
  • onHide:页面隐藏或切入后台时触发。 如 navigateTo 或  tab 切换到其他页面,小程序切入后台等;
  • onUnload:页面卸载时触发。如 redirectTo 或 navigateBack 到其他页面时。

7、小程序的双向绑定和 Vue 哪里不一样

        小程序里面自己触发双向绑定要使用 this.setData({ key :value }) 来更新值。vue 使用 this.data.key = value 即可。

8、哪些方法可以用来提高微信小程序的应用速度

  • 提高页面加载速度
  • 用户行为预测
  • 减少默认 data 的大小
  • 组件化方案

9、如何封装微信小程序的数据请求

  • 将所有的请求接口配置(url)放在一个 js 文件中并导出;
  • 将请求方法(如:get、post 等)封装于一个 js 文件中并导出;
  • 导入前面两个 js 文件获取 url 和请求方法,然后发送数据请求。

10、小程序怎么给事件传值

        在组件标签上通过绑定 data-key = value , 然后事件处理函数里面通过 e.currentTarget.dataset.key 来获取标签上绑定的值。

<button bindtap="get" data-name="测试"> 拿到传值</button>
get(e){ console.log(e.currentTarget.dataset.name) }

11、bindtap 和 catchtap 区别 

        bindtap 不会阻止冒泡,catchtap 可以阻止冒泡。

12、小程序有哪些传递数据的方法

  • 使用全局变量实现数据传递。在 app.js 文件中定义全局变量 globalData, 将需要存储的信息存放在里面;
  • 使用 navigateTo 与 redirectTo 的时候,可以将数据拼接在 url 后面,然后在目标页面的 onLoad 生命周期中获取传递过来的值;
  • 使用本地缓存 storage。

13、简述下 navigateTo(),redirectTo(),switchTab(),navigateBack(),reLaunch() 的区别

  • wx.navigateTo():保留当前页面,然后跳转到某个页面。但是不能跳转到 tabbar 页面;
  • wx.redirectTo() :关闭当前页面,然后跳转到某个页面。但是不能跳转到 tabbar 页面;
  • wx.switchTab():跳转到某个 tabbar 页面,并关闭其他所有非 tabbar 页面;
  • wx.navigateBack():关闭当前页面,返回到上一页面或目标页面。可通过 getCurrentPages 获取当前的页面栈,决定需要返回几层;
  • wx.reLaunch():关闭所有页面,打开某个页面。

14、小程序 wx:if 和 hidden 的区别

        wx:if 有更高的切换消耗,hidden 有更高的初始渲染消耗。如果频繁切换,用 hidden,如果在运行时条件不轻易改变则使用 wx:if。

15、在小程序中如何获取用户信息

        使用 button 并设置其属性:open-type="getUserInfo",在 bindgetuserinfo 绑定的回调函数中通过 e.detail 获取。

<button open-type="getUserInfo" "bindgetuserinfo"="eventhandle">获取用户信息</button>

16、小程序中如何实现分享功能

  • 转发给朋友:监听用户点击页面内转发按钮(button 组件 open-type="share")或右上角菜单“转发”按钮的行为,然后在页面的 onShareAppMessage() 函数中自定义转发内容。
  • 分享到朋友圈:监听右上角菜单“分享到朋友圈”按钮的行为, 然后在页面的  onShareTimeline() 函数中自定义分享内容。

17、小程序中如何用像Vant一样的第三方组件

  • 在命令行中执行:npm init,初始化项目
  • 安装组件
  • 在小程序开发工具中,选择【工具】菜单 -> 选择【构建 npm】命令

18、小程序如何实现父子组件传参

  • 父传子:在子组件中定义属性,父组件在引用子组件的时候通过设置属性的值给子组件传值;
  • 子传父:在组件中绑定一个自定义事件,在子组件中通过 triggerEvent('myevent', myEventDetail) 触发这个事件,给父组件传值。

19、如何实现下拉刷新

  • 通过在 app.json(全局)或者页面的 json 中配置 "enablePullDownRefresh": true,开启下拉刷新;
  • 也可使用 scroll-view 组件,当滚动到顶部会触发 scrolltoupper 事件,在这个事件里自定义实现下拉刷新。

20、小程序 onPageScroll 方法的使用注意什么

        由于此方法调用频繁,不需要时应该去掉,不要保留空方法,避免在此方法中频繁调用 setData() 或同步 API。

21、小程序视图渲染结束后回调

        使用 setData(data, callback),在 callback 回调方法中添加后续操作代码。

22、webview 的页面怎么跳转到小程序导航的页面

        小程序导航的页面可以通过 switchTab 跳转,但默认情况是不会重新加载数据的。若需加载新数据,则在 success 属性中处理:

success: function (e) {
    var page = getCurrentPages().pop();
    if (page == undefined || page == null) return;
    page.onLoad();
}

        webview 的页面,则通过:

wx.miniProgram.switchTab({
    url: '/pages/index/index'
})

23、webview 中的页面怎么跳回小程序中?

        webview 网页中可使用 JSSDK1.3.2 提供的接口返回小程序页面

<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>

// javascript
wx.miniProgram.navigateTo({url: '/pages/login/login'+'$params' })

24、微信小程序登陆流程 

小程序面试题,微信小程序,微信小程序,小程序文章来源地址https://www.toymoban.com/news/detail-577983.html

到了这里,关于微信小程序常见面试题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Linux常见面试题,应对面试分享

    Linux常见面试题,应对面试分享

    1.cpu占⽤率太⾼了怎么办? 排查思路是什么,怎么定位这个问题,处理流程 其他程序: 1.通过top命令按照CPU使⽤率排序找出占⽤资源最⾼的进程 2.lsof查看这个进程在使⽤什么⽂件或者有哪些线程 3.询问开发或者⽼⼤,是什么业务在使⽤这个进程 4.是否可以将这台机器隔离,不影响

    2024年02月13日
    浏览(14)
  • java面试常问,zookeeper常见面试题

    java面试常问,zookeeper常见面试题

    什么是 Spring Boot? 为什么要用 Spring Boot? Spring Boot 的核心配置文件有哪几个?它们的区别是什么? Spring Boot 的配置文件有哪几种格式?它们有什么区别? Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的? 开启 Spring Boot 特性有哪几种方式? Spring Boot 需要独立的容器

    2024年03月15日
    浏览(16)
  • Tomcat面试题+http面试题+Nginx面试题+常见面试题

    1、Tomcat的缺省端口是多少?怎么修改? 答:缺省端口是8080,若要修改,可以进入Tomcat的安装目录下找到conf目录下的server.xml文件,找到该文件中的Connector字段中的port。 2、Tomcat有哪几种connector运行模式(服务的请求方式)? 答:三种。修改它的运行模式需要在主配置文件中

    2023年04月10日
    浏览(14)
  • 入职微软一月后的感悟,谈谈面试经历及入职体验,web前端常见面试题

    入职微软一月后的感悟,谈谈面试经历及入职体验,web前端常见面试题

    在某一天,我在某 App 上被一个微软的陌生人勾搭,简单地电面后一拍即合,我向他投递了简历。 正式的面试一共有四轮,三轮技术面 + 一轮 AA 面(大老板),每轮持续时间一个小时左右。 除了最后一面聊了聊人生、理想、逻辑推理等非技术内容。其他三面基本上是项目算

    2024年04月26日
    浏览(15)
  • 基于安卓Java试题库在线考试系统uniapp 微信小程序

    基于安卓Java试题库在线考试系统uniapp 微信小程序

    本文首先分析了题库app应用程序的需求,从系统开发环境、系统目标、设计流程、功能设计等几个方面对系统进行了系统设计。开发出本题库app,主要实现了学生、教师、测试卷、试题、考试等。总体设计主要包括系统功能设计、该系统里充分综合应用Mysql数据库、JAVA等相关

    2024年02月07日
    浏览(50)
  • 精品微信小程序基于Uniapp+springboot的考试试卷试题刷题系统的设计与实现

    精品微信小程序基于Uniapp+springboot的考试试卷试题刷题系统的设计与实现

    《[含文档+PPT+源码等]精品微信小程序基于Uniapp+springboot的刷题系统的设计与实现》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功! 软件开发环境及开发工具: 开发语言:Java 后台框架:springboot、ssm 安卓框架:Uniapp JDK版本:JDK1.8 服

    2024年02月21日
    浏览(48)
  • 微信小程序面试题

    标签名字有点不一样 多了一些 wx:if 这样的属性以及 {{ }} 这样的表达式 开发工具限制:WXML仅能在微信小程序开发工具中预览,而HTML可以在浏览器内预览。 组件封装不同:WXML对组件进行了重新封装,为后续的性能优化提供了可能,同时避免开发者写出低质量的代码。 没有

    2024年02月09日
    浏览(10)
  • 微信小程序相关面试题

    WXML是微信小程序的一种标记语言,而HTML是Web开发中最常用的标记语言之一。它们之间的异同如下: 语法不同:WXML与HTML的语法有很大的不同,WXML更加简洁,标签名也不同。 标签不同:WXML中的标签与HTML中的标签也有很大的不同,WXML中的标签更加专注于小程序的功能和特性。

    2024年02月12日
    浏览(12)
  • 【前端面试题——微信小程序】

    【前端面试题——微信小程序】

    标签名字有点不一样 多了一些 wx:if 这样的属性以及 {{ }} 这样的表达式 开发工具限制:WXML仅能在微信小程序开发工具中预览,而HTML可以在浏览器内预览。 组件封装不同:WXML对组件进行了重新封装,为后续的性能优化提供了可能,同时避免开发者写出低质量的代码。 没有

    2024年02月09日
    浏览(12)
  • 微信小程序面试题汇总

    微信小程序面试题汇总

    HTML篇 CSS篇 JS篇 Vue篇 TypeScript篇 React篇 前端面试题汇总大全(含答案超详细,HTML,JS,CSS汇总篇)-- 持续更新 前端面试题汇总大全二(含答案超详细,Vue,TypeScript,React,Webpack 汇总篇)-- 持续更新 1. 请谈谈WXML与标准的html的异同? (1) WXML是小程序框架设计的一套标签语言,用

    2024年02月15日
    浏览(7)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包