- 【转】微信小程序:开发之前要知道的三件事
前言微信之父张小龙在年初的那次演讲中曾表示:“我自己是很多年的程序员,我觉得我们应该为开发的团队做一些事情”。几个月后,微信正式推出微信应用号(即微信小程序),在互联网中掀起了又一波热潮。 于是,很多人准备要开发微信的小程序,如果你真的想要开发小程序,就要先学会一套微信特制的“开发语言”。为了更好地上手这门开发语言,下面这三件事你一定要知道: 语言与文件微信小程序来发与其他平台开发的最大差异在于:微信使用的开发语言和文件很“个性”。 小程序所使用的程序文件类型大致分为以下几种: WXML(WeiXin Mark Language, 微信标记语言) WXSS(WeiXin Style Sheet,微信样式表) JS(JavaScript, 小游戏的主体) 在语言方面,下程序看似重新定义了一套标准。但实际上,他们与“前端三件套”(HTML、CSS和JavaScript)差不太多。来来来,看一下微信小程序开发语言和“前端三件套”的异同点。 [图片] 界面搭建1、基本逻辑WXML和WXSS两种文件是小程序界面元素声明及样式描述文件。 WXML最大的特点是以视图(View)的方式串联界面元素,并通过程序逻辑(AppService)将信息更新实时传递至视图层。 View类似于HTML中的div元素,在构建的时候,View可以被多级嵌套,View内可以放置任意视觉元素。 需要注意的是,元素一旦超出屏幕之外,用户就无法看到了,这是与HTML哟较大的不同。小程序哟专门用于滚动的视图。如果希望界面是一个可以自由滚动的界面(例如列表等),可以使用scroll-view视图,在WXSS中将其大小调整为整个屏幕,并设置scroll-y(上下滚动)或scroll-x(左右滚动)为true, 注意,小程序中不能直接使用DOM控制WXML元素。如果需要进行数据更新,就要使用WXML提供的数据绑定及元素渲染方法,还有一点,小程序的栅格排版系统使用的是Flex布局,它是W3C在2009年提出的一种排版标准。 2、绑定数据对于单个字段,开发者可以使用数据绑定的方法进行信息更新。绑定的数据除了在加载的时候可以更新,也可以在JS主程序中以函数形式进行更新,更新同样可以反应到界面上被绑定的数据中。 3、条件渲染与列表(循环)渲染条件渲染适用于有意外情况提示的页面(如无法加载列表或详情时,做出提示等等)。它的渲染带有触发条件,即符合条件时渲染这个页面,否则忽略或渲染另一端代码。两个花括号所包含的判断条件中的变量于主程序JS代码中的data中声明。将同一元素渲染代码进行集合。循环的数据可以通过数组的方式写入data中供WXML访问。渲染完毕后,渲染判断条件的变动可以影响界面变动。 4、模板与引用WXML支持使用模板与引用减少代码体积。模板是在WXML代码中对相同的代码进行复用的方式。可以将多个模板写入至同一个文件,并使用import在其他文件中进行引用。如果需要整个页面引用,需要使用include。 5、样式通过WXSS样式表,开发者可以定义WXML中的元素样式。WXSS与CSS代码一样,可以直接使用选择器选择元素,在WXML中也可以直接定义元素的id和class以便于在WXSS文件中进行样式定义。 6、用户操作与事件响应由于微信使用的不是HTML,所以也不能通过添加超链接(a元素)的方式来检测用户的点击事件。对于需要监听点击事件的元素,应该在WXML中使用bindtap属性或catchtap属性进行绑定。除了点击一次,微信也提供按住、开始触摸、松手等事件响应。在WXML中绑定好一个事件之后,就能在主程序中使用。其他的API中也有相应的事件,这些事件乐意在微信小程序的官方文档中查阅到。当需要在小程序的页面间进行跳转时,应该使用wx.navigateTo()方式。 注意,有关于页面层级跳转,微信将层级跳转限制在5层。在开发时一定注意不要超过了相应限制。 网络请求方式网络访问小程序支持三种请求方式:HTTP连接、WebSocket、文件收发连接。 HTTP连接:请求后直接返回结果,连接结束; Socket连接:持续性连接,当一方主动关闭连接时,连接结束; 文件收发连接:顾名思义,发生在文件传输时的连接。(录制的语音和选择的照片都需要这个连接完成)。 注意,通过小程序访问网络需要服务器必须支持HTTPS连接,且端口必须为443。同时,小程序只能访问开发者在登记小程序时设定的服务器地址。 开发语言和“前端三件套”的异同点 HTML与WXML:两者差异比较大,如果之前没有接触过Android开发,可能会觉得有些头疼。事实上,WXML更像是Android开发中的界面XML描述文件,适合于程序界面的构建;而HTML则倾向于文章的展示(这与HTML的历史有关),以及互联网页面的构建。 WXSS与CSS:两者在语言上几乎没有差别,可以直接通用。 JS文件:小程序的JS文件与前端开发使用的JS几乎没有区别,只是小程序的JS新增了微信的一些API接口,并去除了一些不必要的功能(如DOM)。 在有眼上,小程序完全向学习成本最低的前端开发看齐,但这不代表所有开发者都能无缝迁移。如果你是从前端开发转向小程序,就要注意这两点: 1、HTML与WXML两种文件的构建思想差异较大,如果之前只接触过前端开发,需要一点时间才能适应WXML的编写方法。 2、虽然小程序使用的是前端语言,但不代表可以继续沿用的开发思想进行开发。小程序对前端开发的要求从【构建界面】升级成【开发完整应用】,前端开发需要在意识上进行转变。 原作者:liujia216 授权网站:http://blog.csdn.net/liujia216/article/details/53162385
2016-11-17 - 微信小程序审核相关贴指引
给提问的开发者的建议: 1、审核申诉问题,建议优先走腾讯客服(工单)流程。(路径:kf.qq.com) 2、提问之前先查询文档、通过社区右上角搜索已经存在的问题。 3、写一个简明扼要的标题,并在正文描述清楚你的问题。 4、对于提供信息过少的问题,会直接关闭,请提供完整信息以后重新打开问题。 一、各位开发者,当审核未通过,请按如下模版反馈问题至工单或者社区发帖 1、小程序注册主体类型(企业、个人还是第三方): 2、小程序账号(APPID、原始ID或者邮箱,三者之一即可): 3、问题描述(具体问题介绍): 4、问题截图(客户端问题界面截图): 二、代码审核时间 登录微信公众平台小程序,进入开发管理,开发版本中展示已上传的代码,管理员可提交审核或是删除代码,代码审核7个工作日完成。 注:常规审核时间为2-3个工作日完成,如无特殊情况且未超过7个工作日发帖将不予反馈,请耐心等待审核结果。 三、小程序未通过会涉及哪些类型? 主要涉及有小程序服务类目、基础信息、上线后功能使用、内容、可用性和完整性。 注意事项服务类目小程序发布的内容与小程序申请的服务类目要保持一致。 小程序发布的内容涉及特殊行业时,未选择相应的类目。特殊行业参考:特殊行业所需资质材料 小程序内容小程序内容不得发布平台支持的服务类目以外的内容:如游戏、虚拟支付等; 不得发布非法博彩,违反相关法律法规的内容。基础信息logo不得侵犯其他品牌权利; 详细小程序简介避免政治敏感、色情、敏感词语的出现; 不得对知名品牌名称添加特殊符号,恶意引导用户。小程序上线后功能使用小程序所实际提供的服务和内容,必须是正式的,不能以Demo形式提交; 不得以使用其他应用程序为条件使用小程序。可用性和完整性ios和安卓系统环境下,小程序首页都无法加载或者一直处于加载状态中。
2017-12-21