当前位置: 首页 > news >正文

沈阳专业制作网站教育培训排行榜前十名

沈阳专业制作网站,教育培训排行榜前十名,黄金软件免费下载,苏州知名网站制作公司近期公司需要开发一个小程序项目,时间非常紧急,在开发过程中遇到几个困扰的问题及解决方案,记录如下:小程序框架选择 基础框架:小程序原生框架 sassui: 采用 vant weapp图表:采用 ec-echarts …
近期公司需要开发一个小程序项目,时间非常紧急,在开发过程中遇到几个困扰的问题及解决方案,记录如下:

小程序框架选择

  • 基础框架:小程序原生框架 + sass
  • ui: 采用 vant weapp
  • 图表:采用 ec-echarts

小程序开发

    • 1 微信小程序 打开问卷星
    • 2 微信小程序 wxs 使用正则的问题
    • 3 微信使用 echarts 层级问题
    • 4 h5 中判断是否在小程序环境中
    • 5 嵌套 h5 中实现分享企微、微信和下载功能
    • 6 vant weapp 样式覆盖处理

1 微信小程序 打开问卷星

小程序功能中有一个满意度调查的功能,不是原生功能,而是使用三方的问卷星网页链接,我们知道,小程序中需要嵌套网页的话,其中一条要求就是需要在网站的根目录下存放校验文件,但我们不可能在问卷星网站下去存放校验文件,所以这个功能当时陷入了困境,偶然查看问卷星的文档,发现其有小程序版同样可以使用问卷调查,但需要一个 activityId ,看格式与网页链接后缀中的一段 path 非常像,如下:
在这里插入图片描述
拿过来试了一下,发现真的可以使用,问题就此解决,代码如下:
在这里插入图片描述

2 微信小程序 wxs 使用正则的问题

因为小程序的机制,我们要在 wxml 中使用函数的话,只能通过 wxs 脚本的方式引入到页面中使用,在使用正则的时候,本人顺其自然的按照 js 中的语法使用正则,导致各种报错,还一头雾水,仔细阅读文档后发现,正则在小程序中的使用语法是不同的,需要使用自带的 getRegExp 方法,并且前后无需 / 作为开始、结束,方法包含两个参数,第一个为正则表达式的字符,第二个为正则的修饰符,代码如下:

var numberWithCommas = function (n) {return n.toString().replace(getRegExp('\B(?=(\d{3})+(?!\d))', 'g'), ',');
}

3 微信使用 echarts 层级问题

参考微信小程序,原生组件同层渲染:https://developers.weixin.qq.com/miniprogram/dev/component/native-component.html#%E5%8E%9F%E7%94%9F%E7%BB%84%E4%BB%B6%E5%90%8C%E5%B1%82%E6%B8%B2%E6%9F%93
在开发者工具中 echarts 的样式会重叠到其它组件上面,但真机中会正常显示,所以如果开发中能看得下去,就可以先不用管,解决方案的代码如下:

<view class="xc-bar"><!-- 目前在开发者工具中会有重叠的情况,真机不会 --><ec-canvas canvas-id="xc-bar" ec="{{ ec }}" id="{{ecid}}"></ec-canvas> <!-- 以下可以解决在开发者工具中重叠情况,暂无必要 --><!-- <ec-canvas canvas-id="xc-bar" force-use-old-canvas ec="{{ ec }}" id="{{ecid}}"></ec-canvas> -->
</view>

4 h5 中判断是否在小程序环境中

项目中嵌入了h5 页面,在不同的环境中,某些功能是不同的,需要我们根据环境的不同来判断处理,判断方式如下,但有一个需要我们注意的问题:

export const isWx = () => {return new Promise(resolve => {try {if (window.__wxjs_environment === 'miniprogram') {resolve('mini-wx');} else {resolve('no-mini-wx');}// window.wx?.miniProgram.getEnv((res: IMini) => {//     if (res.miniprogram) {//         resolve('mini-wx');//     } else {//         resolve('no-mini-wx');//     }// });} catch (err) {resolve('no-mini-wx');console.log(err);}});
};

代码中判断的地方,都是官方文档所提供的,而被注释掉的部分,则是因为在某些情况下,getEnv 方法虽然存在,但并不会执行传入的方法,而导致 Promise 挂起,页面操作卡死。

5 嵌套 h5 中实现分享企微、微信和下载功能

项目中嵌入的h5有多个入口,包含分享功能,在app中可以通过bridge调起原生的分享、下载功能,但是在小程序中,因为平台限制的原因,不能调起小程序的 api,并且提供的jssdk也没有相关功能,所以在实现这个功能时,只能像淘宝等应用一样,把想要分享的数据,一键复制到粘贴板上,h5 粘贴复制的代码如下:

export const copyText = (text: string, cb?: () => unknown) => {const textarea = document.createElement('textarea'); // 创建一个 textarea 元素textarea.value = text; // 将要复制的文本赋值给 textarea 的 value 属性document.body.appendChild(textarea); // 将 textarea 元素添加到页面中textarea.select(); // 选中 textarea 的内容document.execCommand('copy'); // 执行复制命令document.body.removeChild(textarea); // 移除 textarea 元素cb && cb();
};

目前 execCommand 这个方法已被弃用,大家可以自行搜索最新的语法,转换也很简单

6 vant weapp 样式覆盖处理

微信小程序官方文档中说明,需要将 app.json 中的 “style”: “v2” 去除,因为小程序的新版基础组件强行加上了许多样式,难以覆盖,不关闭将造成部分组件样式混乱。

{"style":"v2", // 删除此行 "sitemapLocation": "sitemap.json"}

自定义组件中需要覆盖vant 样式时需要如下设置:

Component({/*** 组件的属性列表*/properties: {},options: { styleIsolation: 'shared', }, // 重点在这!!!})
http://www.yidumall.com/news/73246.html

相关文章:

  • 响应式网站有什么区别新手怎样做网络推广
  • 自己做培训网站网站建设规划书
  • 网站上传文件存储方式郑州网络推广服务
  • 有专门做背景音乐的网站吗seo简单优化
  • 网站外链建设有利于增加网站收录长沙哪里有网站推广优化
  • 免费数据分析网站品牌传播策略
  • 网站开发的步骤过程企业推广平台
  • 网站建设原则包括哪些内容中国站长之家
  • 网站空间和域名区别中小企业管理培训课程
  • 上海网站建设找思创软件培训班
  • 深圳专业手机网站建设论坛推广的步骤
  • 备案怎么关闭网站吗成都网站快速优化排名
  • 建设一个普通的网站需要多少钱微博推广怎么做
  • 做网站网页尺寸是多少钱互动营销
  • 菏泽网站建设便宜臻动传媒怎么开发自己的网站
  • 可以做描文本的网站企业官网seo
  • 百度文库网站立足岗位做奉献百度站长收录入口
  • wordpress邮件回复怎么做网站关键词优化
  • 自己做盗版影视网站网站整站优化公司
  • 天津企业网站设计哪家好千万别手贱在百度上搜这些词
  • 浏览国外服务器的网站网络app推广是什么工作
  • cc域名做网站好吗12345微信公众号
  • 做网站服务器多少钱seo可以提升企业网站的
  • 动态网站 seo百度游戏风云榜
  • 有哪些漫画做的好的网站好seo优化排名易下拉效率
  • 免费虚拟机安卓版郑州seo服务技术
  • 51网站怎么打不开了关键词排名优化网站
  • 网站备案 登录名2023年8月新闻热点事件
  • 美橙表业手表网站seo高级优化方法
  • 资中做网站多少钱免费的api接口网站