全栈开发工程师微信小程序-上

实现swiper组件

swiper

滑块视图容器。

indicator-dots 是否显示面板指示点 false
indicator-color 指示点颜色
indicator-active-color 当前选中的指示点颜色
autoplay 是否自动切换 false
current 当前所在滑块的 index
interval 自动切换时间间隔
duration 滑动动画时长
circular 是否采用衔接滑动 false
vertical 滑动方向是否为纵向 false
display-multiple-items 同时显示的滑块数量
<swiper style='height: 100%; width: 100%;' indicator-dots>
<swiper-item wx:fot="{{pics}}" wx:key="{{item.id}}" style="flex:1;">
<image src="{{item.image}}" mode="" style='position: absolute; height: 100%; width: 100%; opacity: .8;'>
</image>
</swiper-item>
</swiper>
// index.js
<swiper
indicator-dots="{{indicatorDots}}"
autoplay="{{autoplay}}"
interval="{{interval}}"
duration="{{duration}}"
>
<block wx:for="{{imgUrls}}">
<swiper-item>
<image src="{{item}}" class="slide-image" width="355" height="150" />
</swiper-item>
</block>
</swiper>
<button bindtap="changeIndicatorDots">indicator-dots</button>
<button bindtap="changeAutoplay">autoplay</button>
<slider bindchange="intervalChange" show-value min="500" max="2000" />
interval
<slider bindchange="durationChange" show-value min="1000" max="10000" />
duration
// js
Page({
data: {
imgUrls: [
'http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg',
'http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg',
'http://img06.tooopen.com/images/20160818/tooopen_sy_175833047715.jpg'
],
indicatorDots: false,
autoplay: false,
interval: 5000,
duration: 1000
},
changeIndicatorDots(e) {
this.setData({
indicatorDots: !this.data.indicatorDots
})
},
changeAutoplay(e) {
this.setData({
autoplay: !this.data.autoplay
})
},
intervalChange(e) {
this.setData({
interval: e.detail.value
})
},
durationChange(e) {
this.setData({
duration: e.detail.value
})
}
})

显示:

page {
height: 100%;
background-color: #f0f0f0;
}

缓存本地数据

wx.setStorage(Object object)

将数据存储在本地缓存中指定的 key

单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB

key 本地缓存中指定的 key
data 需要存储的内容
只支持原生类型、Date、及能够通过JSON.stringify序列化的对象 wx.setStorage({
key: 'key',
data: 'value'
}) try {
wx.setStorageSync('key', 'value')
} catch (e) { }
onLoad: function (options) {
} onLoad(options) {
}

wx.getStorage(Object object)

从本地缓存中异步获取指定key的内容

wx.getStorage({
key: 'key',
success(res) {
console.log(res.data)
}
}) try {
const value = wx.getStorageSync('key')
if (value) {
// Do something with return value
}
} catch (e) {
// Do something when catch error
}

引用样式

@import "   .wxss";

页面跳转

<scroll-view scroll-x>
<view style="display:flex;">
<navigator url="item?id={{item.id}}" wx:for="{{item.movies}}" wx:key="{{item.id}}"> </navigator>
</view>
</scroll-view>

wx.showLoading(Object object)

显示 loading 提示框

title 	提示的内容
mask 是否显示透明蒙层,防止触摸穿透 wx.showLoading({
title: '加载中',
}) setTimeout(function () {
wx.hideLoading()
}, 2000)

wx.hideLoading是隐藏加载提示的界面交互API

wx.showLoading是显示加载提示的API

template 声明标签
name 用于模板名称 <import src="list"/>
<template is="list"/>

刷新功能

Page.onPullDownRefresh()

监听该页面用户下拉刷新事件

wx.startPullDownRefresh()

wx.stopPullDownRefresh()

Page({
onPullDownRefresh: function(){
wx.stopPullDownRefresh()
}
})

navigationBarTitleText代表小程序的标题.

wx:for是列表渲染标签,默认当前循环项的变量名为item.wx:key用于在动态列表渲染中保存子项的特征和状态.

使用wx.getStorageSync,和wx.getStorage,前者是同步调用,后者是异步调用.前者调用后可以返回结果,后者需要在回调函数中获取结果.

onLoad(options){
var a = wx.getStorageSync('key');
}

wx.getStorageSync(key)是小程序同步缓存API,有Sync字样,都是同步API,缓存获取可能会失败,一般是将同步代码放在try catch代码.

冒泡事件

bind方式绑定的事件具有冒泡属性,

flex 属性

flex 属性是 flex-grow、flex-shrink 和 flex-basis 属性的简写属性
默认值:	0 1 auto
flex: flex-grow flex-shrink flex-basis|auto|initial|inherit;

flex:1 详解

flex 是 flex-grow、flex-shrink、flex-basis的缩写
 flex 的默认值是 0 1 auto
当 flex 取值为 none,则计算值为 0 0 auto
当 flex 取值为 auto,则计算值为 1 1 auto

flex:1 代表什么?

flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto
auto (1 1 auto) 和 none (0 0 auto)

display flex | inline-flex
flex-direction row | row-reverse | column | column-reverse
flex-wrap nowrap | wrap | wrap-reverse

案例:

<style>
#flex {
display: flex;
flex-flow: row wrap;
width: 300px;
}
.item {
width: 80px;
}
<style> <div id="flex">
<div class='item'>1</div>
<div class='item'>2</div>
<div class='item'>3</div>
<div class='item'>4</div>
</div>

flex

flex: 0 auto
flex: initial flex: 0 1 auto
flex: auto flex: 1 1 auto
flex: none flex: 0 0 auto
justify-content flex-start | flex-end | center | space-between | space-around

align-items flex-start | flex-end | center | baseline | stretch
align-self auto | flex-start | flex-end | center | baseline | stretch

align-content flex-start | flex-end | center | space-between | space-around | stretch

flex:1 代表什么?

让所有弹性盒模型对象的子元素都有相同的长度,忽略它们内部的内容.

data.charAt(0)用于提取字符串data的首要字符.

data.subStr(1)用于从位置1截断字符串并返回.

this.data.arr.shift()用于从数组arr的首位抽出一个元素.

this.data.arr.pop()用于将数组arr的顶端,就是最后一个推入的元素抛弃.

isNaN(a)用于判断是不是非数字.

Page.onShareAppMessage(Object)

wx.showShareMenu(OBJECT)

显示当前页面的转发按钮

wx.showShareMenu({
withShareTicket: true
})

wx.hideShareMenu(OBJECT)

隐藏转发按钮

wx.updateShareMenu(OBJECT)

更新转发属性

wx.updateShareMenu({
withShareTicket: true,
success() {
}
})

wx.getShareInfo(OBJECT)

获取转发详细信息

onShareAppMessage(res) {
return {
title: '',
path: '',
}
}

如果看了觉得不错

点赞!转发!

达叔小生:往后余生,唯独有你

You and me, we are family !

90后帅气小伙,良好的开发习惯;独立思考的能力;主动并且善于沟通

简书博客: 达叔小生

https://www.jianshu.com/u/c785ece603d1

结语

  • 下面我将继续对 其他知识 深入讲解 ,有兴趣可以继续关注
  • 小礼物走一走 or 点赞

全栈开发工程师微信小程序 - 上的更多相关文章

  1. 全栈开发工程师微信小程序-上(下)

    全栈开发工程师微信小程序-上(下) icon 图标 success, success_no_circle, info, warn, waiting, cancel, download, search, ...

  2. 全栈开发工程师微信小程序-上(中)

    全栈开发工程师微信小程序-上(中) width: 750rpx; 750rpx代表与屏幕等宽,rpx的缩写responsive pixel,这个单位是可以根据屏幕大小进行自适应调整的像素单位. 小程序 ...

  3. 全栈开发工程师微信小程序-中(下)

    全栈开发工程师微信小程序-中(下) 微信小程序视图层 wxml用于描述页面的结构,wxss用于描述页面的样式,组件用于视图的基本组成单元. // 绑定数据 index.wxml <view> ...

  4. 全栈开发工程师微信小程序-中(中)

    全栈开发工程师微信小程序-中(中) 开放能力 open-data 用于展示微信开放的数据 type 开放数据类型 open-gid 当 type="groupName" 时生效, ...

  5. 全栈开发工程师微信小程序-中

    全栈开发工程师微信小程序-中 多媒体及其他的组件 navigator 页面链接 target 在哪个目标上发生跳转,默认当前小程序,可选值self/miniProgram url 当前小程序内的跳转链 ...

  6. 全栈开发工程师微信小程序-下

    app.json { "pages": ["pages/index/index"] } index.wxml <text>Hello World&l ...

  7. 全栈之路-微信小程序-SKU开发(代码)

    SKU开发是小程序中最难的一部分,思路在分析中已经记录过了,这里主要看一下代码的实现,感觉老师写的代码太棒了,很优雅!主要想记录一下写代码的思路,对面向对象编程的实践. 一.代码结构的分析 1.说明几 ...

  8. 全栈之路-微信小程序-SKU开发(分析)

    SKU是整个小程序中最难完成的部分了,好好记录一下SKU,主要是想记录一下 从最开始拿到这个业务到最终完成这个功能期间的思考过程,至于代码什么的,记录也好,不记录也行,再看! 一.从思路说起 1.SK ...

  9. 全栈之路-微信小程序-架构总览

    第一阶段是用来学习小程序开发的,这个就相当于PC端的网站吧,只不过现在依靠微信强大的流量来将业务搬移到小程序中,对于企业来说,这是一种很好的发展方向,既减少了开发成本,又减少了推广成本,小程序是很被人 ...

随机推荐

  1. 查看linux是否为虚拟机,以及其它信息,cpu,主机型号,主板型号等

    dmidecode -s system-product-name 物理机: [root@swnode1]# dmidecode -s system-product-name I840-GS 虚拟机: ...

  2. node.js 使用NAPI写C++插件,(部分转帖)

    原文:https://www.cnblogs.com/chyingp/p/nodejs-learning-napi.html 可能是版本问题,我用node v10.6.0 遇到了问题 不过解决了. 一 ...

  3. mysql备份最近8天的数据库,老的自动删除方案

    服务器上的处理脚本记录: [root@mysql01 test]# crontab -l0 2 * * * /bin/sh /script/sqlbackup.sh >/dev/null 2&g ...

  4. MySQL数据库和表名大小写敏感开关的打开办法

    背景:window 10系统安装了MySQL57,使用可视化操作工具Navicat Premium 12进行相关操作,一切比较顺利.但在建立数据库和表时,发现大小写命名不敏感.区分大小写输入,保存后默 ...

  5. git学习笔记:常用命令总结

    本文根据廖雪峰的博客,记录下自己的学习笔记.主要记录常用的命令,包括仓库初始化.添加文件.提交修改.新建分支.内容暂存.分支管理.标签管理等内容. git是分布式版本控制系统. 首先是安装,从官网下载 ...

  6. MySQL语法大全_自己整理的学习笔记(MySQL语句 整理二)

    select * from emp; #注释 #--------------------------- #----命令行连接MySql--------- #启动mysql服务器 net start m ...

  7. 字典 Dictionary

    字典 Dictionary {Key-Value} 1.字典是无序的,没有下标(因为有key,取值直接用key值) Key尽量不要用中文编写,以防止编码不同导致取不出来 2.字典常用方法: 查找: ① ...

  8. 很漂亮的PHP验证码(记录)

    在提交表单的时候为了防止机器操作或者是恶意的攻击,在填写表单的时候一般都用验证码来过滤掉一些非法提交数据.今天给大家介绍一款超实用超漂亮的PHP验证码库:Captcha. 安装 使用composer: ...

  9. vue,react,angular

    一.Vue.js:     其实Vue.js不是一个框架,因为它只聚焦视图层,是一个构建数据驱动的Web界面的库.     Vue.js通过简单的API(应用程序编程接口)提供高效的数据绑定和灵活的组 ...

  10. HTTP协议 与 TCP协议 的区别

    TCP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据. TCP/IP和HTTP协议的关系,从本质上来说,二者没有可比性,我们在传输数据时,可以只使用(传输 ...