微信站前端开发注意点(经典微信小程序面试题总结)

一、请你讲述一下微信小程序原理?
1、微信小程序采用JavaScript、WXML、WXSS三种技术进行开发,从技术讲和现有的前端开发差不多,但深入挖掘的话却又有所不同
2、JavaScript:首先JavaScript的代码是运行在微信App中的,并不是运行在浏览器中,因此一些H5技术的应用,需要微信App提供对应的API支持,而这限制住了H5技术的应用,且其不能称为严格的H5,可以称其为伪H5,同理,微信提供的独有的某些API,H5也不支持或支持的不是特别好
3、WXML:WXML微信自己基于XML语法开发的,因此开发时,只能使用微信提供的现有标签,HTML的标签是无法使用的
4、WXSS:WXSS具有CSS的大部分特性,但并不是所有的都支持,而且支持哪些,不支持那些并没有详细的文档
5、微信的架构,是数据驱动的架构模式,它的UI和数据是分离的,所有的页面更新,都需要通过对数据的更改来实现
6、小程序分为两个部分webview和appService。其中webview主要用来展现UI,appService有来处理业务逻辑、数据及接口调用。它们在两个进程中运行,通过系统层JSBridge实现通信,实现UI的渲染、事件的处理
二、分析下微信小程序的优劣势
优势:
1、无需下载,通过搜索和扫一扫就可以打开
2、良好的用户体验:打开速度快
3、开发成本要比App要低
4、安卓上可以添加到桌面,与原生App差不多
5、为用户提供良好的安全保障。小程序的发布,微信拥有一套严格的审查流程, 不能通过审查的小程序是无法发布到线上的
劣势:
1、限制较多。页面大小不能超过1M。不能打开超过5个层级的页面
2、样式单一。小程序的部分组件已经是成型的了,样式不可以修改。例如:幻灯片、导航
3、推广面窄,不能分享朋友圈,只能通过分享给朋友,附近小程序推广。其中附近小程序也受到微信的限制
4、依托于微信,无法开发后台管理功能
三、小程序如何实现下拉刷新?
用view代替scroll-view,,设置onPullDownRefresh函数实现。
1、在json文件中配置enablePullDownRefresh为true(app.json中在window中设置enablePullDownRefresh,此效果作用于全局)
2、在js文件中实现onPullDownRefresh方法,在网络请求完成后调用wx.stopPullDownRefresh()来结束下拉刷新
四、小程序调用后台接口遇到哪些问题?
1、数据的大小有限制,超过范围会直接导致整个小程序崩溃,除非重启小程序;
2、小程序不可以直接渲染文章内容页这类型的html文本内容,若需显示要借住插件,但插件渲染会导致页面加载变慢,所以最好在后台对文章内容的html进行过滤,后台直接处理批量替换p标签div标签为view标签,然后其它的标签让插件来做,减轻前端的时间
五、你是怎么封装微信小程序的数据请求的?
1、将所有的接口放在统一的js文件中并导出
2、在app.js中创建封装请求数据的方法
3、在子页面中调用封装的方法请求数据
想了解更多精彩内容,快来关注阿狸带你学前端