Commit 8f166286 authored by wlxuqu's avatar wlxuqu

1. 优化懒加载的方法

2. 优化步进器的代码逻辑
3. 修改评分组件对支付宝小程序的支持
4. 添加搜索组件的maxlength参数
5. 优化$u.getRect()方法,使其支持支付宝小程序
6. 修改README.md的描述错误
7. 优化按钮点击事件,阻止冒泡
8. 修复Empty组件的历史记录图标显示不全的问题,同时使该组件垂直居中
9. Icon图标组件新增label功能,支持右边和下方插入描述文字
10. 优化NoNetwork无网络提示组件,使其垂直居中
11. 给NumberBox步进器组件添加disabled-input组件,控制输入框是否可输入内容
12. 优化Swiper组件在App上滑动时圆角无效的问题
13. 改正Switch开关选择器参数的拼写错误
14. 添加Upload上传组件控制右上角删除图标的样式参数,可以定义颜色,背景等
15. 新增Card卡片组件
16. 新增Line线条组件
17. 给$u.test.empty改名$u.test.isEmpty,同时保留$u.test.empty,二者功能一致
parent 9d200c0c
/unpackage/dist/* /unpackage/dist/*
/node_modules/* /node_modules/*
/.idea/* /.idea/*
deploy.sh
...@@ -46,7 +46,7 @@ Vue.use(uView); ...@@ -46,7 +46,7 @@ Vue.use(uView);
3. `uni.scss`引入全局scss变量文件 3. `uni.scss`引入全局scss变量文件
```css ```css
/* uni.scss */ /* uni.scss */
@import "uview-ui/themb.scss"; @import "uview-ui/theme.scss";
``` ```
4. `pages.json`配置easycom规则(按需引入) 4. `pages.json`配置easycom规则(按需引入)
......
...@@ -113,7 +113,8 @@ ...@@ -113,7 +113,8 @@
"h5" : { "h5" : {
"template" : "template.h5.html", "template" : "template.h5.html",
"router" : { "router" : {
"mode" : "history" "mode" : "hash",
"base" : ""
}, },
"optimization" : { "optimization" : {
"treeShaking" : { "treeShaking" : {
......
...@@ -2,14 +2,14 @@ ...@@ -2,14 +2,14 @@
"easycom": { "easycom": {
"^u-(.*)": "@/uview-ui/components/u-$1/u-$1.vue" "^u-(.*)": "@/uview-ui/components/u-$1/u-$1.vue"
}, },
"condition": { //模式配置,仅开发期间生效 // "condition": { //模式配置,仅开发期间生效
"current": 0, //当前激活的模式(list 的索引项) // "current": 0, //当前激活的模式(list 的索引项)
"list": [{ // "list": [{
"name": "test", //模式名称 // "name": "test", //模式名称
"path": "pages/componentsA/navbar/index", //启动页面,必选 // "path": "pages/componentsB/line/index", //启动页面,必选
"query": "id=1&name=2" //启动参数,在页面的-+onLoad函数里面得到 // "query": "id=1&name=2" //启动参数,在页面的-+onLoad函数里面得到
}] // }]
}, // },
"pages": [ "pages": [
// 演示-组件 // 演示-组件
{ {
...@@ -578,6 +578,20 @@ ...@@ -578,6 +578,20 @@
{ {
"root": "pages/componentsB", "root": "pages/componentsB",
"pages": [ "pages": [
// line-线条
{
"path": "line/index",
"style": {
"navigationBarTitleText": "line-线条"
}
},
// card-卡片
{
"path": "card/index",
"style": {
"navigationBarTitleText": "card-卡片"
}
},
// divider-分割线 // divider-分割线
{ {
"path": "divider/index", "path": "divider/index",
......
<template>
<view class="">
<view class="u-card-wrap">
<u-card @click="click" @head-click="headClick" :title="title" :sub-title="subTitle" :thumb="thumb" :padding="padding" :border="border">
<view class="" slot="body">
<view class="u-body-item u-flex u-border-bottom u-col-between u-p-t-0">
<view class="u-body-item-title u-line-2">
瓶身描绘的牡丹一如你初妆,冉冉檀香透过窗心事我了然,宣纸上走笔至此搁一半
</view>
<image src="https://img11.360buyimg.com/n7/jfs/t1/94448/29/2734/524808/5dd4cc16E990dfb6b/59c256f85a8c3757.jpg" mode="aspectFill"></image>
</view>
<view class="u-body-item u-flex u-row-between u-p-b-0">
<view class="u-body-item-title u-line-2">
釉色渲染仕女图韵味被私藏,而你嫣然的一笑如含苞待放
</view>
<image src="https://img12.360buyimg.com/n7/jfs/t1/102191/19/9072/330688/5e0af7cfE17698872/c91c00d713bf729a.jpg" mode="aspectFill"></image>
</view>
</view>
<view class="" slot="foot" v-if="bottomSlot">
<u-icon name="chat-fill" size="34" color="" label="30评论"></u-icon>
</view>
</u-card>
</view>
<view class="u-config-wrap u-demo">
<view class="u-config-title u-border-bottom">
参数配置
</view>
<view class="u-config-item">
<view class="u-item-title">左上角图标</view>
<u-subsection vibrateShort :list="['显示', '隐藏']" @change="thumbChange"></u-subsection>
</view>
<view class="u-config-item">
<view class="u-item-title">内边距</view>
<u-subsection vibrateShort current="1" :list="['20', '30', '40']" @change="paddingChange"></u-subsection>
</view>
<view class="u-config-item">
<view class="u-item-title">底部</view>
<u-subsection vibrateShort :list="['显示', '隐藏']" @change="bottomChange"></u-subsection>
</view>
<view class="u-config-item">
<view class="u-item-title">外边框</view>
<u-subsection vibrateShort :list="['显示', '隐藏']" @change="borderChange"></u-subsection>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
title: '素胚勾勒出青花,笔锋浓转淡',
subTitle: '2020-05-15',
thumb: 'http://pic2.sc.chinaz.com/Files/pic/pic9/202002/hpic2119_s.jpg',
padding: 20,
bottomSlot: true,
border: true
}
},
methods: {
thumbChange(index) {
this.thumb = index == 0 ? 'http://pic2.sc.chinaz.com/Files/pic/pic9/202002/hpic2119_s.jpg' : '';
},
paddingChange(index) {
this.padding = [20, 30, 40][index];
},
bottomChange(index) {
this.bottomSlot = !index;
},
borderChange(index) {
this.border = !index;
},
click(index) {
console.log(index);
},
headClick(index) {
console.log(index);
}
}
}
</script>
<style scoped lang="scss">
.u-demo {
padding-top: 0;
}
.u-card-wrap {
background-color: $u-bg-color;
padding: 1px;
}
.u-body-item {
font-size: 32rpx;
color: #333;
padding: 20rpx 10rpx;
}
.u-body-item image {
width: 120rpx;
flex: 0 0 120rpx;
height: 120rpx;
border-radius: 8rpx;
margin-left: 12rpx;
}
</style>
<template>
<view class="u-demo">
<view class="u-demo-wrap">
<view class="u-demo-title">演示效果</view>
<view class="u-demo-area">
<u-line color="red" :color="color" :length="length" :direction="direction" :hair-line="hairLine"></u-line>
</view>
</view>
<view class="u-config-wrap">
<view class="u-config-title u-border-bottom">
参数配置
</view>
<view class="u-config-item">
<view class="u-item-title">颜色</view>
<u-subsection vibrateShort :list="['primary', 'success', 'warning', 'error', 'info']" @change="colorChange"></u-subsection>
</view>
<view class="u-config-item">
<view class="u-item-title">细边</view>
<u-subsection vibrateShort :list="['是', '否']" @change="hairLineChange"></u-subsection>
</view>
<view class="u-config-item">
<view class="u-item-title">方向</view>
<u-subsection vibrateShort :list="['水平', '垂直']" @change="directionChange"></u-subsection>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
direction: 'row',
hairLine: true,
length: '100%',
color: this.$u.color['primary']
}
},
methods: {
colorChange(index) {
this.color = this.$u.color[['primary', 'success', 'warning', 'error', 'info'][index]];
},
hairLineChange(index) {
this.hairLine = !index;
},
directionChange(index) {
this.direction = index == 0 ? 'row' : 'col';
if(index == 0) this.length = '100%';
else this.length = '50rpx';
},
}
}
</script>
<style scoped lang="scss">
.u-demo {
}
</style>
<template> <template>
<!-- <view class="wrap">
<view class="item">
<u-alert-tips @close="close" closeText="close" :closeAble="true" :show="show" type="primary" :title="title" :description="description"></u-alert-tips>
</view>
<view class="item">
<u-alert-tips type="warning" :showIcon="false" :closeAble="true" :title="title" :description="description"></u-alert-tips>
</view>
<view class="item">
<u-alert-tips type="success" :title="title" :closeAble="false" :description="description"></u-alert-tips>
</view>
<view class="item">
<u-alert-tips type="error" :title="title" closeText="close" :closeAble="true"></u-alert-tips>
</view>
<view class="item">
<u-alert-tips type="info" :title="title"></u-alert-tips>
</view>
</view> -->
<view class="u-demo"> <view class="u-demo">
<view class="u-demo-wrap"> <view class="u-demo-wrap">
<view class="u-demo-title">演示效果</view> <view class="u-demo-title">演示效果</view>
......
<template> <template>
<view class=""> <u-card :title="title" :sub-title="subTitle" :thumb="thumb">
<u-modal v-model="show" @confirm="confirm" :async-close="true"></u-modal> <view class="" slot="body">
<u-button @click="showModal">弹起Modal</u-button> <view class="u-body-item u-flex u-border-bottom u-col-between u-p-t-0">
<view class="u-body-item-title u-line-2">瓶身描绘的牡丹一如你初妆,冉冉檀香透过窗心事我了然,宣纸上走笔至此搁一半</view>
<image src="https://img11.360buyimg.com/n7/jfs/t1/94448/29/2734/524808/5dd4cc16E990dfb6b/59c256f85a8c3757.jpg" mode="aspectFill"></image>
</view> </view>
<view class="u-body-item u-flex u-row-between u-p-b-0">
<view class="u-body-item-title u-line-2">釉色渲染仕女图韵味被私藏,而你嫣然的一笑如含苞待放</view>
<image src="https://img12.360buyimg.com/n7/jfs/t1/102191/19/9072/330688/5e0af7cfE17698872/c91c00d713bf729a.jpg" mode="aspectFill"></image>
</view>
</view>
<view class="" slot="foot"><u-icon name="chat-fill" size="34" color="" label="30评论"></u-icon></view>
</u-card>
</template> </template>
<script> <script>
export default { export default {
data() { data() {
return { return {
show: false title: '素胚勾勒出青花,笔锋浓转淡',
subTitle: '2020-05-15',
thumb: 'http://pic2.sc.chinaz.com/Files/pic/pic9/202002/hpic2119_s.jpg',
};
} }
}, };
onLoad: function(opt) { </script>
}, <style scoped lang="scss">
methods:{ .u-card-wrap {
showModal() { background-color: $u-bg-color;
this.show = true; padding: 1px;
},
confirm() {
setTimeout(() => {
this.show = false;
}, 3000)
} }
.u-body-item {
font-size: 32rpx;
color: #333;
padding: 20rpx 10rpx;
} }
}
</script>
.u-body-item image {
width: 120rpx;
flex: 0 0 120rpx;
height: 120rpx;
border-radius: 8rpx;
margin-left: 12rpx;
}
</style>
...@@ -146,6 +146,14 @@ export default [{ ...@@ -146,6 +146,14 @@ export default [{
}, { }, {
groupName: '布局组件', groupName: '布局组件',
list: [{ list: [{
path: '/pages/componentsB/line/index',
icon: 'line',
title: 'Line 线条',
},{
path: '/pages/componentsB/card/index',
icon: 'card',
title: 'Card 卡片',
}, {
path: '/pages/componentsC/mask/index', path: '/pages/componentsC/mask/index',
icon: 'mask', icon: 'mask',
title: 'Mask 遮罩层', title: 'Mask 遮罩层',
......
...@@ -46,7 +46,7 @@ Vue.use(uView); ...@@ -46,7 +46,7 @@ Vue.use(uView);
3. `uni.scss`引入全局scss变量文件 3. `uni.scss`引入全局scss变量文件
```css ```css
/* uni.scss */ /* uni.scss */
@import "uview-ui/themb.scss"; @import "uview-ui/theme.scss";
``` ```
4. `pages.json`配置easycom规则(按需引入) 4. `pages.json`配置easycom规则(按需引入)
......
<template> <template>
<u-popup mode="bottom" :border-radius="borderRadius" :popup="false" v-model="value" :maskCloseAble="maskCloseAble" <u-popup mode="bottom" :border-radius="borderRadius" :popup="false" v-model="value" :maskCloseAble="maskCloseAble"
length="auto" :safeAreaInsetBottom="safeAreaInsetBottom" @close="popupClose" :z-index="uZIndex"> length="auto" :safeAreaInsetBottom="safeAreaInsetBottom" @close="popupClose" :z-index="uZIndex">
<view class="u-tips u-border-bottom" v-if="tips.text" :style="tipsStyle"> <view class="u-tips u-border-bottom" v-if="tips.text" :style="[tipsStyle]">
{{tips.text}} {{tips.text}}
</view> </view>
<block v-for="(item, index) in list" :key="index"> <block v-for="(item, index) in list" :key="index">
......
...@@ -98,16 +98,6 @@ ...@@ -98,16 +98,6 @@
return { return {
} }
}, },
watch: {
show(val) {
if (val == false) {
// 先opacity隐藏,再移除
setTimeout(() => {
this.showAlert = false;
}, 300);
}
}
},
computed: { computed: {
// 计算字体颜色,如果没有自定义的,就用uview主题颜色 // 计算字体颜色,如果没有自定义的,就用uview主题颜色
computeColor() { computeColor() {
......
...@@ -26,7 +26,7 @@ ...@@ -26,7 +26,7 @@
@opensetting="opensetting" @opensetting="opensetting"
@launchapp="launchapp" @launchapp="launchapp"
:style="[buttonStyle]" :style="[buttonStyle]"
@tap="click($event)" @tap.stop="click($event)"
:hover-class="getHoverClass" :hover-class="getHoverClass"
:loading="loading" :loading="loading"
> >
......
<template>
<view
class="u-card"
@tap.stop="click"
:class="{ 'u-border': border, 'u-card-full': full }"
:style="{
borderRadius: full ? 0 : borderRadius + 'rpx',
margin: margin
}"
>
<view
class="u-card__head"
:style="[headStyle, {padding: padding + 'rpx'}]"
:class="{
'u-border-bottom': headBorderBottom
}"
@tap="headClick"
>
<view v-if="!$slots.head" class="u-flex u-row-between">
<view class="u-card__head--left u-flex" v-if="title">
<image
:src="thumb"
class="u-card__head--left__thumb"
mode="aspectfull"
v-if="thumb"
:style="{
height: thumbWidth + 'rpx',
width: thumbWidth + 'rpx',
borderRadius: thumbCircle ? '100rpx' : '6rpx'
}"
></image>
<text
class="u-card__head--left__title u-line-1"
:style="{
fontSize: titleSize + 'rpx',
color: titleColor
}"
>
{{ title }}
</text>
</view>
<view class="u-card__head--right" v-if="subTitle">
<text
class="u-card__head__title__text"
:style="{
fontSize: subTitleSize + 'rpx',
color: subTitleColor
}"
>
{{ subTitle }}
</text>
</view>
</view>
<slot name="head" v-else />
</view>
<view @tap="bodyClick" class="u-card__body" :style="[bodyStyle, {padding: padding + 'rpx'}]"><slot name="body" /></view>
<view
class="u-card__foot"
@tap="footClick"
:style="[footStyle, {padding: $slots.foot ? padding + 'rpx' : 0}]"
:class="{
'u-border-top': footBorderTop
}"
>
<slot name="foot" />
</view>
</view>
</template>
<script>
/**
* card 卡片
* @description 卡片组件一般用于多个列表条目,且风格统一的场景
* @tutorial https://www.uviewui.com/components/line.html
* @property {Boolean} full 卡片与屏幕两侧是否留空隙(默认false)
* @property {String} title 头部左边的标题
* @property {String} title-color 标题颜色(默认#303133)
* @property {String | Number} title-size 标题字体大小,单位rpx(默认30)
* @property {String} sub-title 头部右边的副标题
* @property {String} sub-title-color 副标题颜色(默认#909399)
* @property {String | Number} sub-title-size 副标题字体大小(默认26)
* @property {Boolean} border 是否显示边框(默认true)
* @property {String | Number} index 用于标识点击了第几个卡片
* @property {String} margin 卡片与屏幕两边和上下元素的间距,需带单位,如"30rpx 20rpx"(默认30rpx)
* @property {String | Number} border-radius 卡片整体的圆角值,单位rpx(默认16)
* @property {Object} head-style 头部自定义样式,对象形式
* @property {Object} body-style 中部自定义样式,对象形式
* @property {Object} foot-style 底部自定义样式,对象形式
* @property {Boolean} head-border-bottom 是否显示头部的下边框(默认true)
* @property {Boolean} foot-border-top 是否显示底部的上边框(默认true)
* @property {String} thumb 缩略图路径,如设置将显示在标题的左边,不建议使用相对路径
* @property {String | Number} thumb-width 缩略图的宽度,高等于宽,单位rpx(默认60)
* @property {Boolean} thumb-circle 缩略图是否为圆形(默认false)
* @event {Function} click 整个卡片任意位置被点击时触发
* @event {Function} head-click 卡片头部被点击时触发
* @event {Function} body-click 卡片主体部分被点击时触发
* @event {Function} foot-click 卡片底部部分被点击时触发
* @example <u-card padding="30" title="card"></u-card>
*/
export default {
name: 'u-card',
props: {
// 与屏幕两侧是否留空隙
full: {
type: Boolean,
default: false
},
// 标题
title: {
type: String,
default: ''
},
// 标题颜色
titleColor: {
type: String,
default: '#303133'
},
// 标题字体大小,单位rpx
titleSize: {
type: [Number, String],
default: '30'
},
// 副标题
subTitle: {
type: String,
default: ''
},
// 副标题颜色
subTitleColor: {
type: String,
default: '#909399'
},
// 副标题字体大小,单位rpx
subTitleSize: {
type: [Number, String],
default: '26'
},
// 是否显示外部边框,只对full=false时有效(卡片与边框有空隙时)
border: {
type: Boolean,
default: true
},
// 用于标识点击了第几个
index: {
type: [Number, String, Object],
default: ''
},
// 用于隔开上下左右的边距,带单位的写法,如:"30rpx 30rpx","20rpx 20rpx 30rpx 30rpx"
margin: {
type: String,
default: '30rpx'
},
// card卡片的圆角
borderRadius: {
type: [Number, String],
default: '16'
},
// 头部自定义样式,对象形式
headStyle: {
type: Object,
default() {
return {};
}
},
// 主体自定义样式,对象形式
bodyStyle: {
type: Object,
default() {
return {};
}
},
// 底部自定义样式,对象形式
footStyle: {
type: Object,
default() {
return {};
}
},
// 头部是否下边框
headBorderBottom: {
type: Boolean,
default: true
},
// 底部是否有上边框
footBorderTop: {
type: Boolean,
default: true
},
// 标题左边的缩略图
thumb: {
type: String,
default: ''
},
// 缩略图宽高,单位rpx
thumbWidth: {
type: [String, Number],
default: '60'
},
// 缩略图是否为圆形
thumbCircle: {
type: Boolean,
default: false
},
// 给head,body,foot的内边距
padding: {
type: [String, Number],
default: '30'
}
},
data() {
return {};
},
methods: {
click() {
this.$emit('click', this.index);
},
headClick() {
this.$emit('head-click', this.index);
},
bodyClick() {
this.$emit('body-click', this.index);
},
footClick() {
this.$emit('foot-click', this.index);
}
}
};
</script>
<style lang="scss" scoped>
.u-card {
position: relative;
overflow: hidden;
font-size: 28rpx;
background-color: #ffffff;
box-sizing: border-box;
&-full {
// 如果是与屏幕之间不留空隙,应该设置左右边距为0
margin-left: 0 !important;
margin-right: 0 !important;
}
&:after {
border-radius: 20rpx;
}
&__head {
&--left {
color: $u-main-color;
&__thumb {
margin-right: 16rpx;
}
&__title {
max-width: 400rpx;
}
}
&--right {
color: $u-tips-color;
}
}
&__body {
color: $u-content-color;
}
&__foot {
color: $u-tips-color;
}
}
</style>
...@@ -36,7 +36,7 @@ export default { ...@@ -36,7 +36,7 @@ export default {
text: '无权限' text: '无权限'
}, },
history: { history: {
image: '', image: '',
text: '无历史记录' text: '无历史记录'
}, },
news: { news: {
......
...@@ -100,7 +100,7 @@ ...@@ -100,7 +100,7 @@
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
padding-top: 30%; height: 100%;
} }
.u-image { .u-image {
......
...@@ -55,7 +55,7 @@ ...@@ -55,7 +55,7 @@
* @tutorial https://www.uviewui.com/components/field.html * @tutorial https://www.uviewui.com/components/field.html
* @property {String} type 输入框的类型(默认text) * @property {String} type 输入框的类型(默认text)
* @property {String} icon label左边的图标,限uView的图标名称 * @property {String} icon label左边的图标,限uView的图标名称
* @property {Boolean} right-icon 输入框右边的(默认false) * @property {Boolean} right-icon 输入框右边的图标名称,限uView的图标名称(默认false)
* @property {Boolean} required 是否必填,左边您显示红色"*"号(默认false) * @property {Boolean} required 是否必填,左边您显示红色"*"号(默认false)
* @property {String} label 输入框左边的文字提示 * @property {String} label 输入框左边的文字提示
* @property {Boolean} password 是否密码输入方式(用点替换文字),type为text时有效(默认false) * @property {Boolean} password 是否密码输入方式(用点替换文字),type为text时有效(默认false)
......
<template> <template>
<text class="uicon" :class="customClass" :style="[iconStyle]" @tap="click" :hover-class="hoverClass" @touchstart="touchstart"></text> <view class="u-icon" :class="[labelPos == 'bottom' ? 'u-flex-col u-row-center' : 'u-flex u-col-center']">
<text class="u-icon__icon" :class="customClass" :style="[iconStyle]" @tap="click" :hover-class="hoverClass" @touchstart="touchstart"></text>
<text v-if="label" class="u-icon__label" :style="{
color: labelColor,
fontSize: labelSize + 'rpx',
marginLeft: labelPos == 'right' ? marginLeft + 'rpx' : 0,
marginTop: labelPos == 'bottom' ? marginTop + 'rpx' : 0,
}">{{label}}</text>
</view>
</template> </template>
<script> <script>
...@@ -9,7 +17,14 @@ ...@@ -9,7 +17,14 @@
* @tutorial https://www.uviewui.com/components/icon.html * @tutorial https://www.uviewui.com/components/icon.html
* @property {String} name 图标名称,见示例图标集 * @property {String} name 图标名称,见示例图标集
* @property {String} color 图标颜色(默认inherit) * @property {String} color 图标颜色(默认inherit)
* @property {String Number} size 图标字体大小,单位rpx(默认32) * @property {String | Number} size 图标字体大小,单位rpx(默认32)
* @property {String | Number} label-size label字体大小,单位rpx(默认28)
* @property {String} label 图标右侧的label文字(默认28)
* @property {String} label-pos label文字相对于图标的位置,只能right或bottom(默认right)
* @property {String} label-color label字体颜色(默认#606266)
* @property {String | Number} margin-left label在右侧时与图标的距离,单位rpx(默认6)
* @property {String | Number} margin-top label在下方时与图标的距离,单位rpx(默认6)
* @property {String} label-pos label相对于图标的位置,只能right或bottom(默认right)
* @property {String} index 一个用于区分多个图标的值,点击图标时通过click事件传出 * @property {String} index 一个用于区分多个图标的值,点击图标时通过click事件传出
* @property {String} hover-class 图标按下去的样式类,用法同uni的view组件的hover-class参数,详情见官网 * @property {String} hover-class 图标按下去的样式类,用法同uni的view组件的hover-class参数,详情见官网
* @event {Function} click 点击图标时触发 * @event {Function} click 点击图标时触发
...@@ -52,6 +67,36 @@ export default { ...@@ -52,6 +67,36 @@ export default {
customPrefix: { customPrefix: {
type: String, type: String,
default: 'uicon' default: 'uicon'
},
// 图标右边或者下面的文字
label: {
type: String,
default: ''
},
// label的位置,只能右边或者下边
labelPos: {
type: String,
default: 'right'
},
// label的大小
labelSize: {
type: [String, Number],
default: '28'
},
// label的颜色
labelColor: {
type: String,
default: '#606266'
},
// label与图标的距离(横向排列)
marginLeft: {
type: [String, Number],
default: '6'
},
// label与图标的距离(竖向排列)
marginTop: {
type: [String, Number],
default: '6'
} }
}, },
data() { data() {
...@@ -93,8 +138,12 @@ export default { ...@@ -93,8 +138,12 @@ export default {
<style scoped lang="scss"> <style scoped lang="scss">
@import '../../iconfont.css'; @import '../../iconfont.css';
.uicon { .u-icon {
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
} }
.u-icon__label {
}
</style> </style>
<template>
<view class="u-line" :style="[lineStyle]">
</view>
</template>
<script>
/**
* line 线条
* @description 此组件一般用于显示一根线条,用于分隔内容块,有横向和竖向两种模式,且能设置0.5px线条,使用也很简单
* @tutorial https://www.uviewui.com/components/line.html
* @property {String} color 线条的颜色(默认#e4e7ed)
* @property {String} length 长度,竖向时表现为高度,横向时表现为长度,可以为百分比,带rpx单位的值等
* @property {String} direction 线条的方向,row-横向,col-竖向(默认row)
* @property {Boolean} hair-line 是否显示细线条(默认true)
* @example <u-line color="red"></u-line>
*/
export default {
name: 'u-line',
props: {
color: {
type: String,
default: '#e4e7ed'
},
// 长度,竖向时表现为高度,横向时表现为长度,可以为百分比,带rpx单位的值等
length: {
type: String,
default: '100%'
},
// 线条方向,col-竖向,row-横向
direction: {
type: String,
default: 'row'
},
// 是否显示细边框
hairLine: {
type: Boolean,
default: true
}
},
computed: {
lineStyle() {
let style = {};
style.backgroundColor = this.color;
if(this.direction == 'row') {
style.height = '1px';
style.width = this.length;
if(this.hairLine) style.transform = 'scaleY(0.5)';
} else {
style.width = '1px';
style.height = this.length;
if(this.hairLine) style.transform = 'scaleX(0.5)';
}
return style;
}
}
}
</script>
<style scoped lang="scss">
.u-line {
vertical-align: middle;
display: inline-flex;
}
</style>
...@@ -60,6 +60,10 @@ ...@@ -60,6 +60,10 @@
} }
}, },
mounted() { mounted() {
uni.setNavigationBarColor({
frontColor: '#000000',
backgroundColor: '#ffffff',
})
this.isIOS = (uni.getSystemInfoSync().platform === 'ios'); this.isIOS = (uni.getSystemInfoSync().platform === 'ios');
uni.onNetworkStatusChange((res) => { uni.onNetworkStatusChange((res) => {
this.isConnected = res.isConnected; this.isConnected = res.isConnected;
...@@ -187,10 +191,12 @@ ...@@ -187,10 +191,12 @@
} }
.u-inner { .u-inner {
padding-top: 200rpx; height: 100vh;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
justify-content: center;
margin-top: -15%;
} }
.u-tips { .u-tips {
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
}"> }">
<u-icon name="minus" :size="size"></u-icon> <u-icon name="minus" :size="size"></u-icon>
</view> </view>
<input :disabled="disabled" :class="{ 'u-input-disabled': disabled }" v-model="inputVal" class="u-number-input" @blur="onBlur" <input :disabled="disabledInput || disabled" :class="{ 'u-input-disabled': disabled }" v-model="inputVal" class="u-number-input" @blur="onBlur"
type="number" :style="{ type="number" :style="{
color: color, color: color,
fontSize: size + 'rpx', fontSize: size + 'rpx',
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
* @property {Number} max 用户可输入的最大值(默认99999) * @property {Number} max 用户可输入的最大值(默认99999)
* @property {Number} step 步长,每次加或减的值(默认1) * @property {Number} step 步长,每次加或减的值(默认1)
* @property {Boolean} disabled 是否禁用操作,禁用后无法加减或手动修改输入框的值(默认false) * @property {Boolean} disabled 是否禁用操作,禁用后无法加减或手动修改输入框的值(默认false)
* @property {Boolean} disabled-input 是否禁止输入框手动输入值(默认false)
* @property {String Number} size 输入框文字和按钮字体大小,单位rpx(默认26) * @property {String Number} size 输入框文字和按钮字体大小,单位rpx(默认26)
* @property {String} color 输入框文字和加减按钮图标的颜色(默认#323233) * @property {String} color 输入框文字和加减按钮图标的颜色(默认#323233)
* @property {String Number} input-width 输入框宽度,单位rpx(默认80) * @property {String Number} input-width 输入框宽度,单位rpx(默认80)
...@@ -104,6 +105,12 @@ ...@@ -104,6 +105,12 @@
index: { index: {
type: [Number, String], type: [Number, String],
default: '' default: ''
},
// 是否禁用输入框,与disabled作用于输入框时,为OR的关系,即想要禁用输入框,又可以加减的话
// 设置disabled为false,disabledInput为true即可
disabledInput: {
type: Boolean,
default: false
} }
}, },
watch: { watch: {
......
...@@ -25,6 +25,8 @@ ...@@ -25,6 +25,8 @@
* @property {String Number} size 星星的大小,单位rpx(默认32) * @property {String Number} size 星星的大小,单位rpx(默认32)
* @property {String} inactive-color 未选中星星的颜色(默认#b2b2b2) * @property {String} inactive-color 未选中星星的颜色(默认#b2b2b2)
* @property {String} active-color 选中的星星颜色(默认#FA3534) * @property {String} active-color 选中的星星颜色(默认#FA3534)
* @property {String} active-icon 选中时的图标名,只能为uView的内置图标(默认star-fill)
* @property {String} inactive-icon 未选中时的图标名,只能为uView的内置图标(默认star)
* @property {String} gutter 星星之间的距离(默认10) * @property {String} gutter 星星之间的距离(默认10)
* @property {String Number} min-count 最少选中星星的个数(默认0) * @property {String Number} min-count 最少选中星星的个数(默认0)
* @property {Boolean} allow-half 是否允许半星选择(默认false) * @property {Boolean} allow-half 是否允许半星选择(默认false)
......
...@@ -170,11 +170,11 @@ export default { ...@@ -170,11 +170,11 @@ export default {
}, },
onTouchEnd() { onTouchEnd() {
if (this.disabled) return; if (this.disabled) return;
this.status = 'end';
if (this.status === 'moving') { if (this.status === 'moving') {
this.updateValue(this.newValue, false); this.updateValue(this.newValue, false);
this.$emit('end'); this.$emit('end');
} }
this.status = 'end';
}, },
updateValue(value, drag) { updateValue(value, drag) {
// 去掉小数部分,同时也是对step步进的处理 // 去掉小数部分,同时也是对step步进的处理
......
...@@ -197,6 +197,7 @@ ...@@ -197,6 +197,7 @@
.u-swiper-wrap { .u-swiper-wrap {
position: relative; position: relative;
overflow: hidden; overflow: hidden;
transform: translateY(0);
} }
.u-swiper-image { .u-swiper-image {
......
...@@ -46,7 +46,7 @@ ...@@ -46,7 +46,7 @@
default: '#2979ff' default: '#2979ff'
}, },
// 关闭时的背景颜色 // 关闭时的背景颜色
unactiveColor: { inactiveColor: {
type: String, type: String,
default: '#ffffff' default: '#ffffff'
}, },
...@@ -80,7 +80,7 @@ ...@@ -80,7 +80,7 @@
switchStyle() { switchStyle() {
let style = {}; let style = {};
style.fontSize = this.size + 'rpx'; style.fontSize = this.size + 'rpx';
style.backgroundColor = this.value ? this.activeColor : this.unactiveColor; style.backgroundColor = this.value ? this.activeColor : this.inactiveColor;
return style; return style;
}, },
loadingColor() { loadingColor() {
......
...@@ -4,8 +4,10 @@ ...@@ -4,8 +4,10 @@
width: width + 'rpx', width: width + 'rpx',
height: width + 'rpx' height: width + 'rpx'
}"> }">
<view v-if="deletable" class="u-delete-icon" @tap.stop="deleteItem(index)"> <view v-if="deletable" class="u-delete-icon" @tap.stop="deleteItem(index)" :style="{
<u-icon class="u-icon" name="close" size="20" color="#ffffff"></u-icon> background: delBgColor
}">
<u-icon class="u-icon" :name="delIcon" size="20" :color="delColor"></u-icon>
</view> </view>
<u-line-progress v-if="showProgress && item.progress > 0 && !item.error" :show-percent="false" height="16" class="u-progress" :percent="item.progress"></u-line-progress> <u-line-progress v-if="showProgress && item.progress > 0 && !item.error" :show-percent="false" height="16" class="u-progress" :percent="item.progress"></u-line-progress>
<view @tap.stop="retry(index)" v-if="item.error" class="u-error-btn">点击重试</view> <view @tap.stop="retry(index)" v-if="item.error" class="u-error-btn">点击重试</view>
...@@ -37,6 +39,9 @@ ...@@ -37,6 +39,9 @@
* @property {Boolean} show-progress 是否显示进度条(默认true) * @property {Boolean} show-progress 是否显示进度条(默认true)
* @property {Boolean} disabled 是否启用(显示/移仓)组件(默认false) * @property {Boolean} disabled 是否启用(显示/移仓)组件(默认false)
* @property {String} image-mode 预览图片等显示模式,可选值为uni的image的mode属性值(默认aspectFill) * @property {String} image-mode 预览图片等显示模式,可选值为uni的image的mode属性值(默认aspectFill)
* @property {String} del-icon 右上角删除图标名称,只能为uView内置图标
* @property {String} del-bg-color 右上角关闭按钮的背景颜色
* @property {String} del-color 右上角关闭按钮图标的颜色
* @property {Object} header 上传携带的头信息,对象形式 * @property {Object} header 上传携带的头信息,对象形式
* @property {Object} form-data 上传额外携带的参数 * @property {Object} form-data 上传额外携带的参数
* @property {String} name 上传文件的字段名,供后端获取使用(默认file) * @property {String} name 上传文件的字段名,供后端获取使用(默认file)
...@@ -178,6 +183,21 @@ ...@@ -178,6 +183,21 @@
width: { width: {
type: [String, Number], type: [String, Number],
default: 200 default: 200
},
// 右上角关闭按钮的背景颜色
delBgColor: {
type: String,
default: '#fa3534'
},
// 右上角关闭按钮的叉号图标的颜色
delColor: {
type: String,
default: '#ffffff'
},
// 右上角删除图标名称,只能为uView内置图标
delIcon: {
type: String,
default: 'close'
} }
}, },
mounted() { mounted() {
......
// 此版本发布于2020-05-12 // 此版本发布于2020-05-16
let version = '1.2.5'; let version = '1.2.6';
export default { export default {
v: version, v: version,
......
...@@ -30,7 +30,6 @@ ...@@ -30,7 +30,6 @@
.u-flex { .u-flex {
display: flex; display: flex;
flex-wrap: wrap;
flex-direction: row; flex-direction: row;
align-items: center; align-items: center;
} }
...@@ -114,40 +113,40 @@ ...@@ -114,40 +113,40 @@
} }
// 定义内外边距,历遍1-80 // 定义内外边距,历遍1-80
@for $i from 1 through 80 { @for $i from 0 through 80 {
// 只要双数和能被5除尽的数 // 只要双数和能被5除尽的数
@if $i % 2 == 0 or $i % 5 == 0 { @if $i % 2 == 0 or $i % 5 == 0 {
// 得出:u-margin-30或者u-m-30 // 得出:u-margin-30或者u-m-30
.u-margin-#{$i}, .u-m-#{$i} { .u-margin-#{$i}, .u-m-#{$i} {
margin: $i + rpx; margin: $i + rpx!important;
} }
// 得出:u-padding-30或者u-p-30 // 得出:u-padding-30或者u-p-30
.u-padding-#{$i}, .u-p-#{$i} { .u-padding-#{$i}, .u-p-#{$i} {
padding: $i + rpx; padding: $i + rpx!important;
} }
@each $short, $long in l left, t top, r right, b bottom { @each $short, $long in l left, t top, r right, b bottom {
// 缩写版,结果如: u-m-l-30 // 缩写版,结果如: u-m-l-30
// 定义外边距 // 定义外边距
.u-m-#{$short}-#{$i} { .u-m-#{$short}-#{$i} {
margin-#{$long}: $i + rpx; margin-#{$long}: $i + rpx!important;
} }
// 定义内边距 // 定义内边距
.u-p-#{$short}-#{$i} { .u-p-#{$short}-#{$i} {
padding-#{$long}: $i + rpx; padding-#{$long}: $i + rpx!important;
} }
// 完整版,结果如:u-margin-left-30 // 完整版,结果如:u-margin-left-30
// 定义外边距 // 定义外边距
.u-margin-#{$long}-#{$i} { .u-margin-#{$long}-#{$i} {
margin-#{$long}: $i + rpx; margin-#{$long}: $i + rpx!important;
} }
// 定义内边距 // 定义内边距
.u-padding-#{$long}-#{$i} { .u-padding-#{$long}-#{$i} {
padding-#{$long}: $i + rpx; padding-#{$long}: $i + rpx!important;
} }
} }
} }
......
var array = require('./array.wxs');
var object = require('./object.wxs');
var PREFIX = 'van-';
function join(name, mods) {
name = PREFIX + name;
mods = mods.map(function(mod) {
return name + '--' + mod;
});
mods.unshift(name);
return mods.join(' ');
}
function traversing(mods, conf) {
if (!conf) {
return;
}
if (typeof conf === 'string' || typeof conf === 'number') {
mods.push(conf);
} else if (array.isArray(conf)) {
conf.forEach(function(item) {
traversing(mods, item);
});
} else if (typeof conf === 'object') {
object.keys(conf).forEach(function(key) {
conf[key] && mods.push(key);
});
}
}
function bem(name, conf) {
var mods = [];
traversing(mods, conf);
return join(name, mods);
}
module.exports.bem = bem;
...@@ -170,5 +170,6 @@ export default { ...@@ -170,5 +170,6 @@ export default {
contains, contains,
range, range,
rangeLength, rangeLength,
empty empty,
isEmpty: empty
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment