转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

时间:2023-01-12 19:43:44

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

今天一波三折,承受了超出预料的压力和煎熬,最后还是决定继续放出我的更新教程。我想我一没有泄露公司的代码,二没有提供泄露开发工具下载,只是从程序猿角度写了篇开发日志。我已经做好了最坏的准备,就算放弃这份工作,也会把完成的教程交给「名片盒」的团队继续更新发布下去!做了就绝不后悔!只是博卡君水平有限,文章还请各位多包容。

以上!开始吧:

小提示:

http://wxopen.notedown.cn/

这里面复刻了微信小程序的 api

第三章:微信小程序项目结构以及配置

找到创建的 demo 文件夹,把项目导入到你的编辑器,这里使用的是 Sublime Text 编辑器。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

这个时候需要根据自己的项目需求结构进行更改了,项目根目录下面是首页渲染的几个 tabBar 页面,以及 app 的一些配置文件,如名片盒项目的 tabBar 是 3 个切换菜单:

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

我们先找到 app.json 文件打开配置好这几个菜单,配置好 tabBar,这个直接把配置文件改成你自己设计的即可。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

App.json 里面有几个配置项:

  • Pages:这个是编写的 js 文件,后缀 .js 这里不需要使用,配置好正确路径即可正常应用到(应用不到在重启微信开发者工具会直接报 page 错误)。

  • Window:配置顶部的一些样式,文档介绍比较详细。

  • tabBar:底部的几项配置,见名知意。

  • networkTimeout:暂时没发现用处,建议看文档。

  • 根据实际项目需求进行添加与更改。

  • iconPath 和 selectedIconPath:底部菜单按钮图片与得到切换点击高亮。

  • "text":可以去掉,全部去掉会发现底部 tabar 高度会减少很多。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

Json 文件配置好后,根据项目进行文件创建,

Demo:存放的是假数据,这一期的开发工具支持 require,假数据使用的是 .js 文件形式,

里面的数据结构 json 一致,把 data 暴露出去即可。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

然后取数据 require 进来即可,这一点使用很方便;

Images:图片路径;

Page:除 tabar 以外的页面;

Servise:服务交付层(与后台联调真实数据时使用);

Wxss:一些公共的 css 文件。

看到这里大家发现每个页面都被连带好三个不同的后缀。分别页面,css,js 目前只能依照这样,是微信应用号的一个规范吧。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

Wxss 文件是引入你写的样式文件,也可以直接在里面写样式。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

Js 文件需全部配置到 pages 里面才能生效。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

下一章:微信小程序首页面开发。

第四章:微信小程序首页面开发

进行了各种准备与配置后,来到首页开发。首先需要实现首页效果图如下:

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

Template 名片很多,需要用模板。

这里需要微信提供的基础组件大致是 input(搜索框)、

action-sheet(右边是个底部下拉菜单,需要下拉菜单)、

Scroll-view (右边 ABC 跳转)、(这个目前实现还有点问题,正在攻克中)。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

View 是块元素,整个搜索框的一个样式。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

  • 名片夹:由于该项目主打名片功能,故很多地方使用,所以需要把名片以 template 分离出来。

  • Template:定义一个模板,name 模板的名字其实是个作用域。

  • Block:循环控制,名片很多,必须用循环出来,和很多操作数据的前端框架循环差不多。

  • 支持自定义属性 data,这里用作判断线上名片以及线下名片。

View 里面是一些数据引入,里面是支持三目运算符。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

引入 template 时非常方便,is 和 name 一样,data 是 nameData 传递过来的数据填充。

一切都绑定数据为中心点。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

取到数据具体操作根据你数据结构:

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

这里的数据结构和 json 数据结构一样,

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

这里如要传到页面的话即是

this.setData({

nameData:card_list_name.data.cards,

timeData:card_list_time.data.cards

});

因为页面遍历的是 nameData,timeData

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

可以看下打印出来的数据结构,根据你的结构进行解析与传递。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

也可以看下这里对数据的一些操作。(这里须根据定义的 json 数据格式来操作的)

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

名片的样式由于很多页面需要使用放在 common.css 里面,这个 common.css 是所有页面都需要用到,一些初始化设置。它是在 pp.wxss 里面引用之后才能被映射到全局 APP。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

搜索框:其中 bindChange 为输入框发生改变事件。微信提供的 bindchange 在支持方面还有小问题,目前是失去焦点才能触发到此事件的发生,待后续完善吧,先实现功能再说。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

bindInputChange:function(e){

//发生搜索事情

var self = this; //this绑定,这个this指向微信的提供window

var Text = e.detail.value.toUpperCase();//取到输入的内容

if(Text==""){   //如果输入为空一些东西需要显示否则不显示

show_letter ="block";

}else{

        show_letter= "none";

}

this.setData({

        show_letter:show_letter,

        showSheet:true

});

var res = nameData;   获取到传递的数据

if(data_type=="name"){

}else if(data_type=="time"){

        res= timeData;

};

for(var k in res){  //for-in循环取到data里面的cards

var data =res[k].cards;

for(var i =0;i<data.length;i++){  //循环取到需要搜索的关键字对比

If(data[i].userName!=null&& data[i].userName.indexOf(Text)!=-1){

data[i]["display"]= "block";  //存在就是赋值显示

}else{

data[i]["display"]= "none"; // 不存在赋值不显示

}

}

}

}

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

菜单栏:做到菜单栏,使用微信提供的下拉菜单组件 action-sheet,它被触发的条件在这里。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

一切以绑定事件为起点:

bindButtonTapSheet:function(e){

//调取底部下拉菜单栏

}

还是得先布好局才能被调动。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

Js 配置:

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

Data 初始化数据:

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

这里得取非,直接设置 false 调不出来: 调用事件。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

调出来还得去掉它啊:如下相同即可

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

取消直接上事件即可。(分为菜单栏外部与底部)

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

//好了,就是这么简单。实现效果简单,体验效果确实非常不错。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

还需要个 loading 效果(暂时没做动画,后期再考虑。)

Loading 布局

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

首页的最外层 view

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

根据微信的生命周期

Onload:function(e){

this.setData({

toastDisplay:”block”,

htmlWrapDisplay:”none”

})

},

onShow:function(e){

this.setData({

toastDisplay:”none”,

htmlWrapDisplay:”block”

})

}

加载条完成。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

扫一扫,直接调用拍照功能,从这里看到微信提供的拍照 api 使用起来非常快速,只需根据需求配置即可。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

点击扫一扫之后,在开发者工具即可看到如下效果。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

做到这里说明下,dom 长度有限制,页面的结构太长,也是无法渲染的,暂且把公司排序暂时先去掉了。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

左边的 ABC 跳转(还在继续完善中)。

这里还有个左滑删除名片功能,微信没有提供这个在移动端很实用的功能真的比较遗憾,后面得花点时间自己写下(后续完善)。

好了,今天更新的内容就先到这里。后续的内容「名片盒」的服务号会按照约定帮我每日更新发布出来。大家每天可以进到这个服务号输入「应用号」、「小程序」或者「教程」,能获取教程更新列表。

感谢「名片盒」团队的信任和全力支持。

博卡君之所以选择这个服务号动手术,是因为从服务号角度它更像一个 APP 化的工具,相比我们公司在做的媒体性服务号,更有工具化改造价值:里面包括调用扫描、检索、分享、积分等复杂功能。感兴趣的朋友可以对照现在的服务号和开发教程印证。

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

好了,不罗嗦了。教程会在「名片盒」和开源中国保持更新,QQ 群就当做大家相互交流学习的平台吧,有兴趣的朋友也可以来。

QQ 群号:

371736433(二群)

383863133(三群

欢迎关注微信公众平台:上帝派来改造世界的人

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!

转载:第二弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!每日更新!的更多相关文章

  1. 微信小程序&lpar;应用号&rpar;开发教程

    本文档将带你一步步创建完成一个微信小程序,并可以在手机上体验该小程序的实际效果.这个小程序的首页将会显示欢迎语以及当前用户的微信头像,点击头像,可以在新开的页面中查看当前小程序的启动日志.下载源码 1 ...

  2. 转载:第四弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿,每日更新!

    感谢大家支持!博卡君周末休息了两天,今天又回到战斗状态了.上周五晚上微信放出官方工具和教程了,推荐程序猿小伙伴们都去试一试,结合教程和代码,写写自己的 demo 也不错. 闲话不多说,开始更新! 第七 ...

  3. 转载:第六弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿!

    大家好!博卡君原计划是能在国庆假期前把小程序的开发教程做完,给大家一套完整.系统的东西,不过由于最近小程序开发工具的拍照组件尚未完善,很多功能还不能顺利实现.我考虑了一下,觉得不如把拍照部分的一些代码 ...

  4. 转载:第三弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿,每日更新!

    感谢朋友们的支持!这两天博卡君收到了很多支持和安慰,也认识了很多志同道合的朋友.目前微信公布的工具和代码都不是正式版,随时有可能调整,大家先体验和学习为主吧.最近这个教程搞得我也心力交瘁了,虽然苦逼, ...

  5. 转载:第五弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿,每日更新!

    博卡君今天继续更新,忙了一天,终于有时间开工写教程.不罗嗦了,今天我们来看看如何实现一些前端的功能和效果. 第八章:微信小程序分组开发与左滑功能实现 先来看看今天的整体思路: 进入分组管理页面--&g ...

  6. 转载:全球首个微信小程序(应用号)开发教程!通宵吐血赶稿,每日更新!

    微信应用号(小程序,「应用号」的新称呼)终于来了! 目前还处于内测阶段,微信只邀请了部分企业参与封测.想必大家都关心应用号的最终形态到底是什么样子?怎样将一个「服务号」改造成为「小程序」? 我们暂时以 ...

  7. 微信小程序&lpar;应用号&rpar;资源汇总整理

    微信小应用资源汇总整理 开源项目 WeApp - 微信小程序版的微信 wechat-weapp-redux-todos - 微信小程序集成Redux实现的Todo list wechat-weapp- ...

  8. 黄聪:微信小程序&lpar;应用号&rpar;资源汇总整理(转)

    微信小应用资源汇总整理 开源项目 WeApp - 微信小程序版的微信 wechat-weapp-redux-todos - 微信小程序集成Redux实现的Todo list wechat-weapp- ...

  9. 微信小程序的功能开发工具跟公众号的差别,小程序是一种减负思维对简单APP是巨大打击

    微信小程序的功能开发工具跟公众号的差别,小程序是一种减负思维对简单APP是巨大打击 摘要: 小程序和公众号最大的区别有如下四点:1.小程序没有粉丝,开发者在后台能看到的只能是累计用户访问数以及实时统计 ...

随机推荐

  1. 图像预处理第9步:存为&period;bmp文件

    //图像预处理第9步:将最终标准化后的字符图像分为单个单个的HDIB保存,并存为.bmp文件 void CChildView::OnImgprcToDibAndSave() { unsigned ch ...

  2. 咏南CS插件开发框架也可BS方式部署

    在几分钟的时间内,CS客户端也可以BS方式部署.

  3. Unit Test单元测试时如何模拟HttpContext

    参考文章:http://blog.csdn.net/bclz_vs/article/details/6902638 http://www.cnblogs.com/PurpleTide/archive/ ...

  4. iOS应用架构谈 开篇 &lpar;转&rpar;

    iOS应用架构谈 开篇  iOS应用架构谈 view层的组织和调用方案 iOS应用架构谈 网络层设计方案 iOS应用架构谈 动态部署方案 iOS应用架构谈 本地持久化方案 缘由 之前安居客iOS ap ...

  5. 编程习题——Maximum Subarray

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  6. mybatis配置开发

    以mysql为例: 一.需要的架包:mybatis.jar和mysql-connector-java.jar 二.一般会有两类配置文件:数据库配置文件和要执行的sql语句 数据库配置文件(配置文件中有 ...

  7. Java多线程之---用 CountDownLatch 说明 AQS 的实现原理

    本文基于 jdk 1.8 . CountDownLatch 的使用 前面的文章中说到了 volatile 以及用 volatile 来实现自旋锁,例如 java.util.concurrent.ato ...

  8. Numpy 线性代数

    Numpy 提供了线性代数库 linalg , 该库包含了线性代数所需的所有功能,可以看卡下面的说明: 函数 描述 dot 两个数组的点积, 即元素对应相乘 vdot 两个向量的点积 inner 两个 ...

  9. mciSendString 多线程播放多首音乐 &amp&semi; 注意事项

    昨天晚上遇到一个问题: 使用 mciSendString  控制播放多首音乐的时候,出现最后一次播放的音乐无法通过 mciSendString ("close mp3") 关闭音乐 ...

  10. MySQL 全文检索 ngram插件

    InnoDB全文索引:N-gram Parser[转] MySql5.7 建立全文索引 InnoDB默认的全文索引parser非常合适于Latin,因为Latin是通过空格来分词的.但对于像中文,日文 ...