VUE编写UI组件

写组件从来就不是一件难事,如果非要说有什么实现障碍,懒算吗???

这是大致总结的一种组件编写思路 整个编写的过程也是按照这个流程来做的。


Paste_Image.png

需求

不管需求是来自于老板、产品亦或是设计师,总之他能讲出道理或者他能拍板,干就是了
设计图
Paste_Image.png
交互说明

正常这个需要设计师或者产品(以下均简称设计)做出交互demo
因为有时候设计不亲自做交互效果的话 他不容易想到一些交互细节,比如

  • 小图在左右滑动后是否要贴边
  • 滑动速度怎么样

在做一些其他丰富的ui组件时 要考虑的细节会更多 如果有时间 并且又能做作出交互demo的话 能更早的确定细节 确定这个组件的需求边界 工程师能更清楚的提前构思组件💭

Paste_Image.png

实现

分拆
写组件就像是造人,捡来树枝作出骨骼,拾起泥料作出皮肤,最后再给上一口的仙气
1⃣骨骼

说实话这是上周的某一天写的 然而现在让我回头看 已经不知道这画的标的是什么意思了


结构过程

大体结构就是


Paste_Image.png

我的习惯组件挂载点为一个容器结构(div) 里面再套一个组件实际的容器
对了要有一个图片查看的遮罩层 别忘了 同组件容器并列
2⃣长相很重要
不管你承认不承认 颜值的重要程度远超一般的辩论论题

开始给你的小人化妆了 用css让每个小块都排好 如果是更复杂的组件 那么要在样式上花费一段时间了 好在这个很简单……
这里主要用到了flex布局和overhidden 没了……没啥可说的……

3⃣这口仙气
你戳死人一下 他不会说 也不会动 你戳活人一下 他会骂你娘

正是有了交互才让组件有了灵气 变得好玩,使用事件来帮它搭上反射弧,接上神经
来分析下这个组件的交互状态

  • 整个组件挂载容器上静止的
  • 包裹小图的容器要能够滑动 左滑 右滑
  • 每个小图要能够响应点击 打开遮罩层并显示大图
  • 大图要响应点击 关闭自身
技术选型
技术哪有对错 组合都是哲学

咱们这里就是vue来做,能利用什么资源呢

  • 单文件 .vue带来的编写组件的便利 模版 样式 交互 都可以写在属于这个组件的地盘
  • vue-touch 基于hammerjs的移动端touch组件 可以很方便的实现左滑右滑 还有 tap
  • watch 监控属性 可以很方便的对数据状态的改变作出相应动作

还有相当一部分童鞋不仔细看文档 文档真的是很重要


vue如何编写可复用组件

有了这些就足够了

代码清单
<template>
    <!--swiper 容器 满宽-->
    <div class="picswiper-container">
        <div v-touch:swipeleft="onSwipeLeft" v-touch:swiperight="onSwipeRight" class="picswiper-wrapper" v-bind:style="transitionObj">
            <div v-touch:tap="lookPic(pic)" class="picswiper-item" v-for="pic in piclist">
                [站外图片上传中……(2)]
            </div>
        </div>
    </div>
    <div v-touch:tap="closeMark()" class="picviewer-mark" v-show="isLookPic">
        [站外图片上传中……(3)]
    </div>
</template>
<script>
    export default{
        props:["piclist","picflag"],
        data(){
            return{
                transitionObj:{
                    'transition-duration':"1000ms",
                    'transform':"translate3d(0, 0, 0)"
                },
                $translateX:10,//阿里适配方案
                swipeLeftCount:0,//滑动次数
                $shouldSwipeCount:1,//滑了几次 默认为1
                $picWidth:3,//每个小图的宽 rem
                $picWrapperWidth:0,//组件容器的宽rem
                isLookPic:false,//是否查看大图
                curPic:""
            }
        },
        methods:{
            onSwipeLeft(eventObj){
                let me = this;
                //计算有几个图片块
                if(me.swipeLeftCount!=me.$data.$shouldSwipeCount){
                    me.swipeLeftCount++
                }
            },
            onSwipeRight(){
                let me = this;
                //计算有几个图片块
                if(me.swipeLeftCount!=0){
                    --me.swipeLeftCount
                }
            },
            lookPic(pic){
                this.curPic = pic
                this.isLookPic = true
            },
            closeMark(){
                this.isLookPic = false
            }
        },
        watch:{
            /**
             * 监控数据
             * 根据当前第几次 来判断滑动方向
             * 在piclist存在时 进行一些配置数据的初始化
             * @param val
             * @param oldVal
             */
            swipeLeftCount(val,oldVal){
                let me = this;
                if(val>oldVal){//往左滑
                    me.transitionObj.transform="translate3d(-"+me.$data.$translateX*val+"rem, 0, 0)"
                }else if(val<oldVal){//向右滑
                    if(me.$data.$translateX/val=="Infinity"){//到头了
                        me.transitionObj.transform="translate3d(0, 0, 0)"
                    }else{
                        me.transitionObj.transform="translate3d(-"+me.$data.$translateX/val+"rem, 0, 0)"
                    }
                }
            },
            /**
             * 监控数据
             * 在piclist存在时 进行一些配置数据的初始化
             * @param val
             * @param oldVal
             */
            piclist(val,oldVal){
                let me = this;
                if(!!val){
                    me.$data.$picWrapperWidth = val.length*me.$data.$picWidth;
                    me.$data.$shouldSwipeCount = Math.floor(me.$data.$picWrapperWidth/me.$data.$translateX)
                }

            }
        }
    }
</script>
<style scope>
.picswiper-container {
    width:100%;
    height:2.666666667rem;
    overflow: hidden;
}
.picswiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-transition-property: -webkit-transform;
    -ms-transition-property: -ms-transform;
    transition-property: transform;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
}
.picswiper-item {
    width:2.666666667rem;
    height:auto;
    -webkit-flex-shrink: 0;
    -ms-flex: 0 0 auto;
    flex-shrink: 0;
    position: relative;
    text-align: center;
    font-size: 18px;
    background: #fff;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    margin-right: 0.2rem;
    overflow: hidden;
}
.picviewer-mark {
    position: fixed;
     top: 0; 
    bottom: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 20009;
    background: rgba(0,0,0,0.8);
    padding-top: 50%;
    text-align: center;
}
</style>

怎么算完了?

  • 完备测试
  • 代码规范优化 包括书写优化 复用优化
  • 性能有没有优化的
  • 文档补充等等等
    对这个组件来说,可优化的点太多了 包括配置项对外暴露 适配方案的兼容 图片数量测试等等,只是想借这个例子记录下写组件的思路

结语

写代码往往很快 思考怎么写往往费力 但也最为好玩
enjoy in think no matter what you do 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,914评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,935评论 2 383
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,531评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,309评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,381评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,730评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,882评论 3 404
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,643评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,095评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,448评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,566评论 1 339
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,253评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,829评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,715评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,945评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,248评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,440评论 2 348

推荐阅读更多精彩内容