百度小程序与微信小程序全面对比

百度小程序已出来了几个月了,我们从官方文档里面可以看出,微信有的功能基本都有,所以也推荐大家去官网学习。文档地址:https://smartprogram.baidu.com/docs/develop/tutorial/codedir/,有遇到问题的可以去百度小程序社区提问:https://smartprogram.baidu.com/forum/(需要登录并且有appid)。

本文分享一些百度小程序与微信小程序的差别。

百度小程序组件hidden属性区别

虽然百度小程序没提到这个属性,但我测试发现它在本地上和真机上都是支持的。但跟微信还是有一点区别:

js:

data: {
    flag:'123'
}

xml:
<view hidden="true">1</view>
<view hidden="false">2</view>
<view hidden="!false">3</view>
<view hidden="{{false}}">4</view>
<view hidden="!flag">5</view>
<view hidden="flag">6</view>
<view hidden="{{flag}}">7</view>
<view hidden="{{!flag}}">8</view>
<view hidden="{{!!flag}}">9</view>
<view hidden="">10</view>

百度小程序输出:
2
4
8

微信输出:
4
8
10

百度:当hidden的值为flase,或者插值{{false}}为flase时,百度组件不会隐藏。其它情况,不管是true或者是空,或者其它值,不为false,或者计算出来的值不为flase,都会被隐藏。

微信:当这个hidden属性为空或者{{false}}插件值为false,才不会隐藏。有一种特殊情况就是直接赋值它为hidden="false",这里的false不被当做布尔值,所以它也被隐藏。

结论:从上面这两个之中我们可以看到 4 和 8 两者都有,那我们做的时候只需要保证 hidden 的值为插值形式,并且插值的结果是布尔值,那两者就能得到一致的表现。

js文件命名空间wx.替换为swan.

wx.request() -> swan.request()
wx.showModal() -> swan.showModal()
wx.canIuse() -> swan.canIuse()
……

swan文件整体替换wx:到s-

主要有两个地方:

1.条件判断

wx:if -> s-if

2.列表循环

wx:for -> s-for
wx:for-item -> s-for-item
wx:key -> s-key

这里还有2点跟微信使用起来有点区别

1.for循环里面,百度是不支持跟if放在同一条语句里面。我们可以通过增加一个block来判断条件

2.条件判断百度是没有使用插值计算。

这是微信的:

<view wx:if="{{condition}}"> True </view>

这是百度的:

<view wx:if="condition"> True </view>

3.组件中的3元运算符,不支持 <= 判断,猜测可能是bug,可能是里面使用了正则判断。

<view>{{ 1 <= 2 ? 'yes' : 'no' }}</view>

解析出来的内容为:

<view>true<="" view=""></=></view>

解决方法是改成 >=,或者<

<view>{{ 2 >= 1 ? 'yes' : 'no' }}</view>

模板

1.声明需要使用的模板,data 是所需要传入到模板的值,当它是对象时,对象字面量是三个大括号包裹,微信是{{}}。

<!-- template-demo.swan-->
<template name="person-card">
    <view>
        <text>位置: {{pos}}</text>
        <text>姓名: {{name}}</text>
    </view>
</template>

<!-- template-demo.swan-->
<template is="person-card" data="{{{person}}}" />

// template-demo.js
Page({
    data: {
        person: {name: 'Lebron James', pos: 'SF', age: 33}
    }
});

2.不支持动态调用

<template name="tid-1">
    <view>1</view>
    <view>{{index}}:{{msg}}</view>
</template>
<template name="tid-2">
    <view>2</view>
    <view>{{index}}:{{msg}}</view>
</template>

当我需要根据tid值来调用某个模板时,例如tid=1时,使用下面的方法调用

<template is="tid-{{tid}}" data="{{{...item}}}"/>

Page({
    data: {
        tid:1
    }
});

上面这种获取不了template tid-1的内容。我们可以通过条件判断来调用模板:

<block s-if="{{ tid == 1}}"><template is="template-1" data="{{{...item}}}" /></block>

Page函数不要使用getData()

由于我之前的页面中获取请求时用的是这个函数,然后我发现百度小程序里面这个函数在onload中无法执行到。另外就是如果直接点击执行这个函数,会报错。

option传递参数,最好加上enCodeURIComponent()

我之前的一个微信小程序传递url时,参数没有格式化,直接传递后,在百度小程序中会发现接收不完整,例如:http://xsps.pchouse.com.cn/ 转化为 http:/xsps.pchouse.com.cn

swan.createSelectorQuery()

这个API要在页面DOM 加载完毕后执行,才能获取到具体的值,如果你直接在onload或者request 的success 里面setData后获取值,同样获取不到内容。

有一种做法就是加一个定时器,在2秒后获取,或者改为当需要的时候才开始获取。

不要使用HTML标签

在百度小程序中,使用了div/ul/li等HTML标签,调试swan tab时,标签会被过滤掉。

<div class="list">
    <ul>
        <li bindtap="test">测试</li>
        <li>测试</li>
        <li>测试</li>
    </ul>
</div>

.list ul{font-size:18px;}

test:function(){
    console.log('test');
}

会发现样式不起作用。另外就是绑定事件也无法起作用,如上面的test,点击后无效,跟刚才说的li标签被过滤同样的道理。

tabBar配置决定了首页

在app.json中,我改了一下pages首页的位置,发现并不起作用,反而tabBar改了第一个标签的地址后,首页也跟着改变,而微信是支持tabBar可以不是首页进来的页面。

wxs 改为 filter

微信的:

WXS(WeiXin Script)是小程序的一套脚本语言,结合 WXML,可以构建出页面的结构。

<!--wxml-->
<wxs module="m1">
var msg = "hello world";

module.exports.message = msg;
</wxs>

<view> {{m1.message}} </view>

页面输出:

hello world

百度的:

Filter 是小程序的过滤器,结合 SWAN 模版,可以构建出页面的结构。

// page.js
Page({
  data: {
    array: [1, 3, 6, 8, 2, 0]
  }
});

// test.filter.js
export default {
    maxin: (arr) => {
        var max = undefined;
        for (var i = 0; i < arr.length; ++i) {
            max = max === undefined ?
            arr[i] :
            (max >= arr[i] ? max : arr[i]);
        }
        return max;
    }
};

<!-- swan模版 -->
<view>{{swan.maxin(array)}}</view>
<filter src="./test.filter.js" module="swan"></filter>

页面输出:

8

自定义组件模板里面没法嵌套模板

建议使用slot

图片路径要补全协议

如下面这两种情况,如果没有补全协议,会无法访问,默认代码为静态解析

<image src="//www1.pchouse.com.cn/2018/weixinminipro/loading.png"></image>

//css 
image{background:url(//www1.pchouse.com.cn/2018/weixinminipro/loading.png)}

import 和 include

import 注意微信中引入的是.wxml的文件,百度这里引入的是.swan的文件,所以要替换掉

在 index.swan 中引用了 item.swan,就可以使用item模板:

<import src="item.swan"/>
<template is="item" data="{{{preson}}}"/>

同理 include也是改文件后缀

<!-- index.swan -->
<include src="header.swan"/>
<view> body </view>
<include src="footer.swan"/>

百度小程序分享到微信,无法打开

百度虽然提供了分享到微信朋友圈和微信好友的功能,但打开微信分享的内容会先提示跳到App Store上,并无法打开百度小程序的页面,分享体验不好,只能分享到百度APP自身的动态,打开后才能访问。

微信转换为百度小程序

1.登录百度小程序开发工具,在工具菜单,有一个一键转换微信的小程序为百度小程序。(前提:有审核通过的appid,并且登录开发者工具)

image

用了官方的工具还是挺好的,对照我上面提到的点,小小的调整应该就差不多了。

2.下载NPM上的一个工具:wx2swan。https://github.com/yican008/wx2swan,跟百度这个转换好像差不多。

安装: npm i -g wx2swan

转换:

wx2swan 微信小程序的目录 (生成swan的目录)

wx2swan ./test/demo ./test/swanDemo

3.使用 Taro 开发

参考链接

  1. 搬家工具转换支持的Feature List
  2. 百度小程序开发问题汇总

这篇文章后续有更新,欢迎收藏原文:http://caibaojian.com/baiduapp-vs-weixinapp.html,编辑于2018.11.15

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 转载链接 注:本文转载知乎上的回答 作者:初雪 链接:https://www.zhihu.com/question...
    pengshuangta阅读 28,476评论 9 295
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • 一、使用展示物注意事项: 1展示物应该先藏好,直到使用时再拿出来。 2使用的展示物应该足够大,使最后一排的人都能够...
    白胖余阅读 1,275评论 2 5
  • 我们来自五湖四海 相聚于文学的世界 简单地书写细密的心思 慷慨地抒发生活的激情 用文字记载喜怒哀乐 用标点断隔过往...
    一个人的宅阅读 2,296评论 31 70
  • 感觉自己什么都不会,什么都不懂,不了解自己,不知道自己到底要做什么,感觉很迷茫。上了大学之后不知道做什么,心好慌。
    八月小长安阅读 170评论 0 0