我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何制作唱吧小程序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何制作唱吧小程序

今天小编给大家分享一下如何制作唱吧小程序的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

1小程序框架浅析

大家都说小程序体验好,即开即用,和普通Webview渲染的H5相比页面启动速度、流畅度等方面好很多,这个问题我认为需要从几个方面考虑,首先,抛开产品业务层面的设计和优化,就是小程序底层框架的设计和实现方面的特点。

当我们新建或打开一个小程序项目(以唱吧比赛小程序为例),即可看到如下图的项目结构。

小程序入口文件为app.js, 全局样式文件为app.wxss,全局配置文件为app.json, 每个页面中再分视图wxml,wxss和逻辑js、文件配置json等,从这里我们可以看出,整个小程序的上层框架,也就是大体分为视图层和逻辑层两个部分。 

小程序采用的MINA框架,View层主要用来渲染页面结构,App Service层用来逻辑处理、数据请求、接口调用,它们在两个线程里运行,整个小程序是只有一个App Service的,并且整个小程序的生命周期内它是常驻内存的。View层主要使用WebView渲染,而App Service逻辑层是使用JSCore运行。

通信方面,View和AppService是双线程通信的,主要通过系统层的JSBridage进行通信,AppService把数据变化通知到View,表现方法也就是setData方法,触发View页面更新,View把触发的事件通知到AppService进行业务处理。

这里要说的是,小程序是没有DOM结构的,那么视图层的渲染是如何做到的呢,就是运行环境中会把pages中的WXML的节点树结构,转化为JS的对象,进行渲染,这也是小程序体验优于普通分享页面的一大原因,省去了很多关于浏览器DOM的操作,由JS运行环境之间进行渲染解析。

2唱吧小程序底层搭建

那么话说回来,基于良好的框架,这次在搭建唱吧小程序底层的时候,我们其实做了哪些事情呢。

首先,我们并没有进行纯Native层的搭建和改造,而是对上述提到的API层的一次的封装,尤其是在关于网络请求的改造和小程序启动的登录流程方面,我们前端团队尝试去做一些分层和优化。

  • 网络请求方面

首先网络请求优化方面,微信提供的请求接口基本长这样:

wx.request({ url: 'test.php', //仅为示例,并非真实的接口地址 data: {    x: '' ,    y: '' }, header: {     'content-type': 'application/json' // 默认值 }, success: function(res) {   console.log(res.data) }})

是不是感觉和之前的某种请求模式很像,没错,就是古老的$.ajax,这时候我们又想起了ajax的回调地狱,如果页面的请求很多,请求的顺序还有限定,瞬间又是各种嵌套,可以说是要从请求到懵逼了。

所以为了解决回调地狱和同时优化请求代码逻辑,我们在封装wx.request的同时,我们在小程序开发中,引入了async/await语法糖,用到了来自facebook的regenerator模块(详情请戳:https://github.com/facebook/regenerator),async、await函数经babel编译后,再用regenerator-runtime模块用于提供功能实现,这一方面也得力于小程序支持ES6语法的编译。

实现过程中,单独用一个公共方法封装,返回wx.request的promise

//wechat.js const request = (url,options) => { return new Promise((resolve, reject) => {   wx.request({     url: url,     method: options.method,     data: Object.assign({}, options.data),     header: options.header,     success: resolve,     fail: reject   }) })}

之后在我们的上层公共库中,编写与请求相关的处理逻辑。

// changba.js const regeneratorRuntime = require('./regenerator-runtime.js')const wechat = require('./wechat')const URI = 'xxx' const requestAPI = async (url,opt) => { const app = getApp() let options = Object.assign({data: {}},opt)   if (/^\/api\/(.+)$/.test(url)) {       url = URI + url;   }   if (!options.method) {       options.method = 'POST';   }   let header = {       'Content-Type': 'application/x-www-form-urlencoded'   }   options.header = options.header || header ;   //除了login方法  其余接口都要加入sessionInfo也就是后端加密过的session_key   if (!url.includes('/checkCode')) {     options.data['sessionInfo'] = app.globalData.sessionkey;   }   let isTimeout = false;   try {     const ree = await wechat.checkSession();   } catch (error) {     isTimeout = true;   };   try {     if (isTimeout) {       let aaa = await login(app);     }     wx.showLoading({       title: '加载中'     });       const res = await wechat.request(url,options)       if (res && res.statusCode) {           if (res.statusCode != 200) {               if (wx.hideLoading) {                   wx.hideLoading()               }               wx.showModal({                   content: wechat.errMsg(res.statusCode).message || '请求失败,请重新尝试',                   title: '提示',                   showCancel: false               })           } else {               if (res.data && res.data.code === 1) {                 if (wx.hideLoading) {                    wx.hideLoading()                 }                 return res.data               } else {                   // xxx 其他情况业务逻辑处理               }           }       }   } catch (error) {       console.log('请求异常信息:' + error)       if (wx.hideLoading) {         wx.hideLoading()       }       wx.showModal({           content: '请求信息异常',           title: '',           showCancel: false       })   }}

上述封装过程中,所以除了考虑到请求超时、检查用户身份等操作,还可以加入session过期等相关其他的业务处理逻辑,这也是自己搭建请求的好处,针对自己的业务需求,进行匹配和改造。

然而在经历这样两层封装之后,在写业务逻辑代码的过程中,就可以一目了然的发送请求了,达到逻辑清晰且书写自如,如果习惯了fetch以及axios的朋友应该都会比较喜欢这种方式。

  async getdata() {    let self = this;    let cb_getdata = await app.changba.requestAPI('/api/xxx', { data: { id: self.data.id } });    if (cb_getdata && cb_getdata.code === 1) {          // xxx    }  }

以上就是“如何制作唱吧小程序”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何制作唱吧小程序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何制作唱吧小程序

今天小编给大家分享一下如何制作唱吧小程序的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1小程序框架浅析大家都说小程序体验好,
2023-06-26

如何制作个人小程序

本篇内容介绍了“如何制作个人小程序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  1.小程序如何制作开发  1.1首先你要确定小程序的定位
2023-06-26

微信小程序如何制作

这篇文章主要为大家展示了“微信小程序如何制作”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“微信小程序如何制作”这篇文章吧。一,善于使用搜索引擎例如搜索引擎。商店都了解SEO和SEM。根据关键字优
2023-06-27

淘客小程序如何制作

今天小编给大家分享一下淘客小程序如何制作的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。  淘客小程序制作步骤有哪些?  第一
2023-06-26

小程序怎么制作小程序码

这篇文章主要介绍“小程序怎么制作小程序码”,在日常操作中,相信很多人在小程序怎么制作小程序码问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”小程序怎么制作小程序码”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-26

微信小程序如何制作旋转动画

这篇文章主要为大家展示了微信小程序如何制作旋转动画,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“微信小程序如何制作旋转动画”这篇文章吧。微信小程序被给予的能量是无穷的,在小程序发展逐渐成熟的当下,
2023-06-26

小程序个人中心页面如何制作

本文小编为大家详细介绍“小程序个人中心页面如何制作”,内容详细,步骤清晰,细节处理妥当,希望这篇“小程序个人中心页面如何制作”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。个人中心制作1. mine.js// pa
2023-06-26

如何制作微信小程序下拉框组件

这篇文章主要为大家展示了“如何制作微信小程序下拉框组件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何制作微信小程序下拉框组件”这篇文章吧。1
2023-06-26

微信小程序如何制作音乐播放器

这篇文章主要介绍“微信小程序如何制作音乐播放器”,在日常操作中,相信很多人在微信小程序如何制作音乐播放器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序如何制作音乐播放器”的疑惑有所帮助!接下来,请跟
2023-06-26

微信小程序怎么制作

这篇文章主要介绍了微信小程序怎么制作的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇微信小程序怎么制作文章都会有所收获,下面我们一起来看看吧。微信小程序制作步骤一:设计 小程序制作所涉及到的设计关于页面的排版和美
2023-06-27

怎么制作小程序商城

这篇文章给大家分享的是有关怎么制作小程序商城的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一,阐明开发计划在开发和设计微信小程序商城之前,商店必须首先阐明他们已完成的微信小程序的基本功能以及关键的业务流程。如今,
2023-06-27

新手小程序怎么制作

这篇文章主要介绍了新手小程序怎么制作的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇新手小程序怎么制作文章都会有所收获,下面我们一起来看看吧。1.前期准备首先要想要自己需要作出的小程序是用来干什么的,是用于电商,
2023-06-27

微信小程序制作如何设置营销活动

这篇文章给大家分享的是有关微信小程序制作如何设置营销活动的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。裂变获客 提供多种营销功能,帮助商家提升线上获客能力,并拓客销售渠道。 1. 拼团:支持老带新拼团,通过给予一
2023-06-27

微信小程序|基于小程序+云开发制作一个菜谱小程序

今天吃什么?这是一个让强迫症左右为难的问题,跟随此文基于小程序+云开发制作一个菜谱小程序,根据现有食材一键生成菜谱,省心又省力。 一、小程序 1. 创建小程序
2023-08-20

小程序制作方式有哪些

这篇文章主要介绍了小程序制作方式有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.模板制作小程序可以通过应用模板直接进行制作。实际上,制作小程序时非常简单。现在,Int
2023-06-27

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录