小程序知识 1

时间:2020-04-12 17:36:53   收藏:0   阅读:71

1. 简单描述下微信小程序的相关文件类型

微信小程序项目结构主要有四个文件类型
主要文件

2. 简述微信小程序原理

微信小程序采用 JavaScriptWXMLWXSS 三种技术进行开发,本质就是一个单页面应用,所有的页面渲染和事件处理,都在一个页面内进行,但又可以通过微信客户端调用原生的各种接口

微信的架构,是数据驱动的架构模式,它的 UI 和数据是分离的,所有的页面更新,都需要通过对数据的更改来实现

小程序分为两个部分 webview 和 appService 。其中 webview 主要用来展现 UI appService 有来处理业务逻辑、数据及接口调用。它们在两个进程中运行,通过系统层 JSBridge 实现通信,实现 UI 的渲染、事件的处理

3. 小程序的双向绑定和vue哪里不一样

小程序直接 this.data 的属性是不可以同步到视图的,必须调用:

this.setData({
    // 这里设置
})

4. 小程序的wxss和css有哪些不一样的地方

WXSS 和 CSS 类似,不过在 CSS 的基础上做了一些补充和修改

rpx 是响应式像素,可以根据屏幕宽度进行自适应。规定屏幕宽为 750rpx。如在 iPhone6 上,屏幕宽度为 375px,共有 750 个物理像素,则 750rpx = 375px = 750 物理像素

/** index.wxss **/
@import ‘./base.wxss‘;

.container{
    color: red;
}

5. 小程序页面间有哪些传递数据的方法

在 app.js 文件中定义全局变量 globalData, 将需要存储的信息存放在里面

// app.js

App({
     // 全局变量
  globalData: {
    userInfo: null
  }
})

使用的时候,直接使用 getApp() 拿到存储的信息

//pageA.js

// Navigate
wx.navigateTo({
  url: ‘../pageD/pageD?name=raymond&gender=male‘,
})

// Redirect
wx.redirectTo({
  url: ‘../pageD/pageD?name=raymond&gender=male‘,
})


// pageB.js
...
Page({
  onLoad: function(option){
    console.log(option.name + ‘is‘ + option.gender)
    this.setData({
      option: option
    })
  }
})

需要注意的问题:

wx.navigateTo 和 wx.redirectTo 不允许跳转到 tab 所包含的页面

onLoad 只执行一次

6. 小程序的生命周期函数

详见 生命周期回调函数

7. 怎么封装微信小程序的数据请求

参考 这里

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

1、提高页面加载速度

2、用户行为预测

3、减少默认 data 的大小

4、组件化方案

9. 微信小程序的优劣势

优势
缺点

10. 怎么解决小程序的异步请求问题

小程序支持大部分 ES6 语法

11. 小程序关联微信公众号如何确定用户的唯一性

如果开发者拥有多个移动应用、网站应用、和公众帐号(包括小程序),可通过 unionid 来区分用户的唯一性,因为只要是同一个微信开放平台帐号下的移动应用、网站应用和公众帐号(包括小程序),用户的 unionid 是唯一的。换句话说,同一用户,对同一个微信开放平台下的不同应用,unionid 是相同的

12. 如何实现下拉刷新

参考 这里

13. bindtap和catchtap的区别是什么

相同点:首先他们都是作为点击事件函数,就是点击时触发。在这个作用上他们是一样的,可以不做区分

不同点:他们的不同点主要是bindtap是不会阻止冒泡事件的,catchtap是阻值冒泡的

14. 简述下 wx.navigateTo()wx.redirectTo()wx.switchTab()wx.navigateBack()wx.reLaunch()的区别</h5>

原文:https://www.cnblogs.com/fs0196/p/12686133.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!