微信小程序基础入门篇

互联网 17-9-12
本篇文章主要介绍了微信小程序入门教程,现在分享给大家,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

4.其它

先看一张小程序初始化的目录:小程序包含一个描述整体程序的 app 和多个描述各自页面的 page。一个小程序主体部分由三个文件组成,必须放在项目的根目录,如下:app.js、app.json、app.wxss;一个小程序页面由四个文件组成,分别是:js、wxml、wxss、json。 详情传送门请戳-->https://mp.weixin.qq.com/debug/wxadoc/dev/framework/structure.html?t=20161107

一、开发工具

微信提供了一款 ' 微信开发者工具 ‘ ,可以直接在小程序的官网下载(https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html?t=20161107)。

需要注意一点的问题是在使用微信开发者工具时,要习惯使用”编译“功能,有的人会遇到自己在编辑器里明明修改了某些地方,但是页面里却没有发生变化,这个时候其实只需要重新编译一次,就妥妥的解决了。同时,遇到一些奇怪问题的时候,也不妨清理一下缓存,也许会有意外收获。

二、布局差异

1.标签

 <view class="group">   <block wx:for="{{iconSize}}">    <icon type="success" size="{{item}}"></icon>   </block>  </view>

我们只需要使用icon组件,不需要去自己设置样式就可以得到对应的icon样式。

在日常小程序开发中,比较常用的组件有view和text,其中用的最多的就是view,view本身并没有默认太多的样式,只有一个display:block样式,所以在我看来view就类似于p,我们也就把它当作p来使用就行了,然后你就会发现布局的时候到处都是view~,就像下图:

满眼全是view这种写法不需要像html一样考虑语义、seo神马的,非常的简单粗暴~。

额外提一下text组件,text拥有view所没有的一个特性就是text组件内的文本可以被复制、可以被复制、可以被复制(重要的事情说三遍~)。如果你希望某段文本可以被复制,那么你只能使用text组件。同时需要注意的一点,text组件内部不能嵌套view组件!嵌套无效!

2.样式

4.支持::before和::after

注:想了解更多请戳-->https://mp.weixin.qq.com/debug/wxadoc/dev/framework/view/wxss.html?t=20161107

二、JS差异

不能获取dom,也不能直接操作dom,那我们该怎么写呢?

1. bind 和 catch

<view id="tapTest" data-hi="WeChat" bindtap="tapName"> Click me! </view>

看到这大家可能发现了bind后面跟着一个tap,这个tap是什么东东?

2. tap

tap其实就是一个事件,你可以理解为click,不过在手机端叫做tap,其它的事件还有:touchstart、touchmove、touchcancel、touchend、longtap。

bindtap=”tapName”组合起来就是绑定个tap事件,tapName则是对应的方法名,在这里需要注意一点,调用方法时不能够使用tapName(“txt”)这种形式来传参,小程序不支持。那么如果我们想要给方法传递一些参数该怎么做呢?接着往下看。

3.event

我们先看一段代码:

Page({   tapName: function(event) {    console.log(event)   }  })

打印出来的结果:

{  "type":"tap",  "timeStamp":895,  "target": {   "id": "tapTest",   "dataset": {    "hi":"WeChat"   }  },  "currentTarget": {   "id": "tapTest",   "dataset": {    "hi":"WeChat"   }  },  "detail": {   "x":53,   "y":14  },  "touches":[{   "identifier":0,   "pageX":53,   "pageY":14,   "clientX":53,   "clientY":14  }],  "changedTouches":[{   "identifier":0,   "pageX":53,   "pageY":14,   "clientX":53,   "clientY":14  }]  }

那么如何修改目标对象的相关信息呢?在这之前我们必须要先了解下currentTarget和target两个属性,前者是绑定事件的组件,后者是触发事件的组件源。理解清楚这两个属性很重要!如果是上面例子这种情况,只有一个view组件,那么这两个属性的值没什么区别,但是如果换成下面的这个例子,就不一样了:

<view id="tap1" data-hi="绑定组件" bindtap="tapName">    <view id="tap2" data-hi="触发组件源"></view>  </view>

我们再输出看看(为了方便对比,只保留下currentTarget和target两个属性):

{   "target": {    "id": "tap2",    "dataset": {     "hi":"触发组件源"    }   },   "currentTarget": {    "id": "tap1",    "dataset": {     "hi":"绑定组件"    }   }  }

通过两个例子,相信大家也注意到了两个属性,data-hi和dataset,这两个属性有什么关系呢?大家应该猜到了,dataset的值其实就是我们设置的data-xxx的值,而xxx则是dataset里面的key。大家对于data-xxx的写法应该不陌生,就是html中常见的自定义属性的写法,而在小程序中,则被用来传参。

4. 改变样式

前面就提到了小程序并不提供获取和操作dom的能力,这就又带来了一个问题,我们如何去动态的改变样式呢?我们先看下例子:

<view class="container" style="overflow: {{screenType?'hidden':'scroll-y'}}" bindtap="bindType">  Page({   data: {    screenType: ''   },   bindType: function(){    this.setData({      screenType: '1'    })   }   })</view>

大家是不是有点明白了呢,我们没有办法直接获取dom然后去改变他的样式,所以我们只能通过data里的属性来控制样式的变化,如上面的代码,overflow的值取决于screenType的值是否存在,如果存在,则overflow: hidden,反之overflow: scroll-y;那么我们只需要改变screenType的值。要改变screenType的值也简单了,小程序提供了this.setData方法,可以设置data内的值。

最后提一下我们熟悉的ajax请求,在小程序里,它不叫ajax,而叫做wx.request。用法和ajax没什么区别,唯一需要特别注意的是,请求必须是https请求!而不是平常的http请求!除了必须要是https请求以外,还需要到小程序的后台里设置合法域名,否则无法请求。

以上就是微信小程序基础入门篇的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 基础
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:小程序项目基本配置

相关资讯