微信小程序常见面试题

article/2025/10/6 14:40:33

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、微信小程序登陆流程 


http://chatgpt.dhexx.cn/article/YcJVjVmk.shtml

相关文章

小程序 组件化 可以实现传值传参

实现的目标&#xff0c;通过自定义组件&#xff0c;可以实现下面这个组件功能&#xff0c;可以自定义文字&#xff0c;点击标题&#xff0c;能够传送当前点击的文字和下标 01.components页面代码 <!--components/w-zujian/w-zujian.wxml--> <view class"kuan&qu…

【微信小程序---子组件传值给父组件】

点击原创或者分类虽然样式如首页一样变化&#xff0c;但是其父组件的最终isActive的值并未发生改变&#xff0c;但是样式发生改变是因为拿取的是Component>里面的properties中的tabs&#xff0c;你点击下去的时候一样拿取tabs数组&#xff0c;所以不会报错。因此子组件必须通…

微信小程序父页面向子组件传值

微信小程序父页面传值 要实现效果&#xff1a; 首页点击立即团购跳转到详情页面传值商品id&#xff0c;详情页在选择商品规格&#xff0c;选择规格为组件需要将商品id同步到组件页面然后进行交互获取规格信息&#xff0c;但是因为setData为异步&#xff0c;所以会导致组件实例…

微信小程序路由跳转,API调用,页面传值

路由跳转 wx.switchTab 跳转到 tabBar 页面&#xff0c;并关闭其他所有非 tabBar 页面。 wx.switchTab({url: /pages/tarbar/index })wx.reLaunch 关闭所有页面&#xff0c;打开到应用内的某个页面。 wx.reLaunch({url: /pages/index/index })wx.redirectTo 关闭当前页面…

微信小程序组件的封装与传值

1、新建component文件夹存放我们的组件&#xff0c;里边存放的就是我们所用的组件&#xff0c;我们今天要做的事弹出框&#xff0c;新建文件夹popup存放我们的组件模板&#xff0c;点击右键选择新建component&#xff0c;就会自动生成组件的模板wxss、wxml、json、js&#xff0…

小程序之父子组件传值详解

小程序之父子组件传值详解 父传子&#xff1a; 1.在pages的同级新建components文件夹&#xff0c;并在components文件夹下新建自定义组件名 2.在父组件的"组件名.json"中引入子组件组件&#xff08;图如下&#xff09; {"usingComponents": {"tab…

小程序页面传值、页面与组件通信方式总结

在小程序开发中&#xff0c;页面传值经常会用到&#xff0c;如果有调用组件和插件的话还会涉及到页面与组件的通信传值等&#xff0c;今天我是想来总结下微信小程序页面和组件传值。 一.页面与页面的传值 1.跳转的url带参传值 微信小程序页面直接传值我们经常用到的是页面UR…

使用搜狗接口对微信公众号爬虫

搜狗搜索因为有微信公众号搜索的接口&#xff0c;所以通过这个接口就可以实现公众号的爬虫 需要安装几个python的库&#xff1a;selenium,pyquery 还使用到phantomjs.exe,这个需要我们自己去下载&#xff0c;然后放在自己的python工程下即可 在输入框输入想要爬取的公众号…

爬取微信公众号文章

新增了GUI界面&#xff0c;效果如图 ************************************************************************************************试了多种方法&#xff0c;发现还是使用自己创建一个公众号再搜索的方式最有用。有三种方法&#xff0c;第一种&#xff1a;用搜狗微信公…

[python]微信公众号文章爬取

[python]微信公众号文章爬取 需求 爬取一些微信公众号的文章 数据来源 1.搜狗微信搜索&#xff0c;可以搜索微信公众号文章&#xff0c;但只能显示该公众号最近十篇的文章 2.通过个人微信公众号中的素材管理&#xff0c;查看其他微信公众号文章 步骤 1.手动从网站上获取co…

Python2.7爬虫——爬取微信公众号文章

今天跟着这篇博客抓取微信公众号文章练习了一下爬虫&#xff0c;运行成功。想和大家分享一下过程中出现的问题和解决方法。 运行环境 windows 7 Pycharm2018 Python 2.7 目录 目录 1.安装必要的Python包 1.1 关于下载selenium包1.2关于下载json包 2.运行之前的准备 代码中需…

基于搜狗搜索的微信公众号爬虫实现(C#版本)

为什么80%的码农都做不了架构师&#xff1f;>>> Author: Hoyho Luo Email: luohaihaogmail.com Source Url:http://here2say.me/11/ 转载请保留此出处 本文介绍基于搜狗的微信公众号定向爬虫&#xff0c;使用C#实现&#xff0c;故取名WeGouSharp。本文中的项目托管…

fiddle python抓取微信公众号文章

分析 1&#xff0c;先进行准备工作&#xff1a;使用fiddle抓包&#xff08;大家可以自行百度怎么使用哦&#xff09; 2&#xff0c;打开电脑端微信&#xff0c;找到需要爬取的公众号 点击进入公众号&#xff0c;再打开fiddle&#xff0c;微信停留在这一步 打开fiddle后再点击…

Java Selenium 爬取微信公众号文章图片.md

项目地址结尾 一、前期准备 1. 下载selenium的驱动 Chrome http://chromedriver.storage.googleapis.com/index.html Firefox https://github.com/mozilla/geckodriver/releases/ IE http://selenium-release.storage.googleapis.com/index.html 下载好驱动然后放到、对…

python爬虫(17)爬出新高度_抓取微信公众号文章(selenium+phantomjs)

个人博客请访问 http://www.x0100.top 一.思路分析 目前所知晓的能够抓取的方法有&#xff1a; 1、微信APP中微信公众号文章链接的直接抓取&#xff08;http://mp.weixin.qq.com/s?__bizMjM5MzU4ODk2MA&mid2735446906&idx1&snece37deaba0c8ebb9badf07e5a5a3bd…

获取微信公众号文章内视频真实地址

PHP获取微信公众号文章内视频与音频真实地址 微信公众号的文章的爬取可以看到这个项目&#xff1a;github 基于QueryList的微信公众号文章获取工具 有任何问题可以留言。 返回数据&#xff1a; 包含音频和视频包含多个视频 原有找到的文章 如何抓取微信公众号文章里面的视频…

Python爬取微信公众号文章、点赞数

代码还是热乎的&#xff0c;只要你细心一步步的慢慢调试&#xff0c;绝壁没问题 前期准备 订阅号&#xff1b;Python&#xff1b;Fiddler&#xff1b;微信账号&#xff1b; 流程 使用用微信公众号生成cookie使用Fiddler抓取微信公众号数据&#xff0c; 获取阅读数通过cooki…

如何爬取微信公众号文章(二)

在如何爬取微信公众号&#xff08;一&#xff09;中完成了将爬取公众号文章的元数据存入数据库&#xff0c;其中包括文章的连接、标题、发布时间、摘要和封面图片等信息。下面介绍如何根据文章链接来爬取文章内容。 开发环境 windows 7 x64python3.7 (Anaconda)vscode 编辑器…

如何爬取微信公众号文章(一)

微信公众号是目前最为流行的自媒体之一&#xff0c;上面有大量的内容&#xff0c;如何将自己感兴趣的公众号内容爬取下来&#xff0c;离线浏览&#xff0c;或者作进一步的分析呢&#xff1f; 下面我们讨论一下微信公众号文章的爬取。 环境搭建 windows 7 x64python3.7 (Anac…

Python 爬虫之微信公众号

Python 爬虫之微信公众号 源代码放在文末。 本次爬虫需要的工具如下: selenium 驱动器对应浏览器的 webdriver一个微信订阅号在 2017 年 6 月左右,微信官方发布一篇文章 https://mp.weixin.qq.com/s/67sk-uKz9Ct4niT-f4u1KA,大致意思就是以后发布文章的时候可以插入其他公…