起因是内部的小程序埋点工具npm包需要新增支持曝光埋点的功能,需要借助标签添加dataset属性信息进行上报,而支付宝小程序提供的API方法my.createIntersectionObserver()在基础库2.7.0版本起才支持在IntersectionObserver.observe 回调中返回目标节点的 dataset 信息,从而满足支持曝光埋点的功能。
按照官方指南操作升级基础库,本地构建…果然报错了QAQ
于是我开始全网搜索支付宝小程序基础库2.x升级指南,结果相关文章寥寥无几,于是一头扎入支付宝小程序官方社区~
并且在这个过程中我发现了小程序基础库2.0升级通知QAQ~
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Oup5dLAa-1669342568061)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/41d039151f4a4e94a88973f85da5836c~tplv-k3u1fbpfcp-zoom-1.image)]
眼看阅读量还不多,但升级基础库肯定是要升级的,那就先来升级看看吧~
首先我们得弄明白什么是基础库?
官方给出的 — 基础库是负责小程序框架的加载的容器,提供小程序框架需要的标准组件和标准 API 接口。
读完官方文档,结合个人理解简单总结一下:
首先官方给出的解释:
也就是说生产环境的基础库其实是升级了的,那么是不是基础库更新是不是完全不需要你做什么了呢?答案是否定的。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-z3EMFxGJ-1669342568062)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/492da2b790754a1a8af7c6a9be1fd6e4~tplv-k3u1fbpfcp-zoom-1.image)]
参照文档本地IDE升级 — https://opendocs.alipay.com/mini/framework/lib-upgrade-v2
文档提供了两种方式:
enableAppxNg: true 字段,不仅省去每次手动勾选,同时必须项目内代码开启才能在用jenkins打包构建并用ci自动上传时生效!这里项目配置要写在编译之前还要区分框架等问题,但你可能刚编译就报错了…无论如何,先把代码跑起来再吧!
由于基础库 2.x 的编译模式更为严格,因此很可能会出现各种编译报错,如下是我踩到的坑。
报错一:identifier(module) is disallowed in sjs
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1we5ymWU-1669342568062)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/3c1531b761d64bb0b15a3baec59554f1~tplv-k3u1fbpfcp-zoom-1.image)]
这是因为sjs模块导入仅支持ESM模块化标准的import / export,需要手动把sjs文件内的导出后引用全部更改为ES6标准的ESM模块化
报错二:identifier(Array) is disallowed in sjs
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1VHbjht4-1669342568063)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/1e87f23fa3c64da9b597146947c09c12~tplv-k3u1fbpfcp-zoom-1.image)]
这段代码存在两个问题:
报错三:本质上同报错二
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-thfDUUWc-1669342568063)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/e11ba1ca55504ca9882878a5726406e4~tplv-k3u1fbpfcp-zoom-1.image)]
本质上同报错二,sjs语法中的对象不支持keys()方法,必须绕开语法不支持的api实现功能,自测通过有两种重写方式:
// 直接重写封装keys()方法
function keys(obj) {
return JSON.stringify(obj)
.replace(REGEXP, '')
.split(',')
.map(function(item) {
return item.split(':')[0];
});
}
// keys()本质是遍历对象获取key的list,手写遍历对象
const str = JSON.stringify(conf);
const arr = str.slice(1, str.length-1).split(',');
for (let i=0; i<arr.length; i++) {
const item = arr[i].split(':');
const key = item[0] && item[0].slice(1, item[0].length-1);
conf[key] && mods.push(key);
}
基本上所有关于sjs语法或者数据类型的报错,都可以参考这份sjs语法文档进行解决https://opendocs.alipay.com/mini/framework/sjs
实现曝光埋点通常都会考虑借助IntersectionObserver对象,支付宝小程序也有自己的API支持。阅读IntersectionObserver对象相关参考文档实现曝光埋点上报后就可以基于2.7+基础库进行验证了。
本地上报成功!
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xJFiJ8Kp-1669342568063)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/54a8cee553aa493c8f99b7e9ffb8ff4b~tplv-k3u1fbpfcp-zoom-1.image)]
准备上线的时候发现生产环境下埋点上报不成功:
于是怀疑是build-upload中间出了问题,所以考虑是项目根目录 mini.project.json 中有关项目编译、打包策略的配置有问题,使用uniapp框架的小程序对应配置文件为manifest.json。
阅读文档之后发现需要开启enableAppxNg为true,所以前面推荐改代码方式启动开发者工具以基础库2.x版本编译,既不用重复勾选,而且生产环境下打包也要手动开启,避免这里走弯路了。
"mp-alipay": {
"enableAppxNg": true
}
同时还有使用小程序cli构建打包和通过nodejs API minidev.build() 传参获取编译打包结果等方式可以参考 — https://opendocs.alipay.com/mini/02q17m
头一次开发支付宝小程序就要搞升级 QAQ,虽然也查了不少文档逛了不少社区问答,但可能还有诸多理解不到位的地方,欢迎指正,也记录一下给新手避我踩过的坑吧~
总归遇到问题时还是要多读文档,其次官方社区看看别人的提问和解决方案。
IntersectionObserver 对象实例 — https://opendocs.alipay.com/mini/api/intersectionobserverIntersectionObserver 对象实例 — https://opendocs.alipay.com/mini/api/pra7yc很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
尝试通过RVM将RubyGems升级到版本1.8.10并出现此错误:$rvmrubygemslatestRemovingoldRubygemsfiles...Installingrubygems-1.8.10forruby-1.9.2-p180...ERROR:Errorrunning'GEM_PATH="/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/ruby-1.9.2-p180@global:/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/rub
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我想用ruby编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
我实际上是在尝试使用RVM在我的OSX10.7.5上更新ruby,并在输入以下命令后:rvminstallruby我得到了以下回复:Searchingforbinaryrubies,thismighttakesometime.Checkingrequirementsforosx.Installingrequirementsforosx.Updatingsystem.......Errorrunning'requirements_osx_brew_update_systemruby-2.0.0-p247',pleaseread/Users/username/.rvm/log/138121