Vue.js学习笔记(4)

© fengyu学习

不出所料,上班果然放松了我学习的心底防线

这篇文章是工作日写好了大半的,今天整理出来,和大家一块分享一下

今天的主要学习内容:Vue.js bind指令DOM 样式不得不说的秘密

1、Vue.js bind指令DOM 样式不得不说的秘密

仔仔细细的看了一遍 Class-Style这一章教程!

发现一个样式都快被绑定出花来,毕竟样式是前端3大模块的一部分,壮哉我大CSS

既然是绑定样式,怎么能没有样式代码呢!

<style>
    .a{
        color: red;
    }

    .b{
        background-color: green;
    }
</style>

好吧,请略过我毫无语义的 className,欣赏一下我的配色方案 red + green better than dog XXX

下面让我们看看以下这5种绑定样式的方法吧

让我们先看1、2两种方式:

<div id="vue_demo" :class="{'a':a, 'b':b}">
    {{content}}
</div>
<script>
    var demo = new Vue({
        el: '#vue_demo',
        data: {
            a: true,
            b: false,
            content: '第一种bind绑定样式方式, class="{\'类名\':true|false, …… }"'
        }
    })
</script>

<div id="vue_demo1" :class="myClass">
    {{ content }}
</div>
<script>
    var demo1 = new Vue({
        el: '#vue_demo1',
        data: {
            myClass : {
                'a' : true,
                'b' : false
            },
            content: '第二种bind绑定样式方式, class="Vue实例对象的属性值,属性格式为{\'类名\' : true|false}"'
        }
    })
</script>
  • bind指令绑定样式方式1: :class="{\'类名\':true|false, …… }"

  • bind指令绑定样式方式2: :class="Vue实例对象的属性值" 属性值格式为{\'类名\' : true|false}

相较之下,第二种方式明显更优,因为它可以形成语义!

在两种方式介绍完后,Class-Style教程中,提到了一句话

我们也可以在这里绑定一个返回对象的**计算属性**。这是一个常用且强大的模式。

我顿时蒙了,因为这句话后面,居然没有例子了!

常用而强大的模式。。怎么常用,如何强大,完全不知道!!!!

于是乎,我自己写了一个四不像的例子。

<div id="vue_demo2" :class="myClass">
    {{ content }}
</div>
<script>
    var demo2 = new Vue({
        el: '#vue_demo2',
        data: {
            style1: {
                'a' : true
            },
            style2: {
                'b' : false
            },
            content: '第三种bind绑定样式方式, class="Vue实例对象的计算值,计算值可由多个样式参数拼接"',
            extend: function(o1, o2, override){
                var o = {};
                var fun = function(arg){
                    for(key in arg){
                        if( (!o.hasOwnProperty(key) && arg.hasOwnProperty(key)) || override){
                            o[key] = arg[key];
                        }
                    }
                }
                fun(o1);
                fun(o2);
                return o;
            },

        },
        computed: {
            myClass: function(){
                return this.extend(this.style1, this.style2);
            }
        }
    })
</script>

我按照文章的描述,使用了一个计算属性,作为样式。但是我确实没有发现这么做有什么比第二种方式高大上的地方。

常用而强大的形容,并没有得到良好的体现,而且我自己还被迫实现了一个合并 js 对象的方法

我在这块的疑惑,希望能有小伙伴可以帮我解答一下!

尽管四不像给我带来了疑惑,但我还是得继续把文章看完

看下面这种绑定方式,v-bind + 数组 绑定样式

<div id="vue_demo3" :class="[a,b]">
    {{ content }}
</div>
<script>
    var demo3 = new Vue({
        el: '#vue_demo3',
        data: {
            a: 'a',
            b: 'b',
            content: '第四种bind绑定样式方式, class="[Vue对象属性值1,Vue对象属性值2]"'
        }
    })
</script>

仅仅从数组的角度来看这种方式,其实平淡无奇,但这个时候,我想到文章刚才提到的计算属性,且看我一试_!

<div id="vue_demo4" :class="myClass">
    {{ content }}
</div>
<script>
    var demo4 = new Vue({
        el: '#vue_demo4',
        data: {
            a: 'a',
            b: 'b',
            isA : true,
            isB : false,
            content: '第五种bind绑定样式方式, class="计算属性,值为[Vue对象属性值1, Vue对象属性值2]"'
        },
        computed: {
            myClass : function() {
                var myClass = [];
                if(this.isA) myClass.push(this.a);
                if(this.isB) myClass.push(this.b);
                return myClass;
            }
        }
    })
</script>

数组的累加颇为简单,只需要用push方法就可以了,而且我们还可以很清晰的加入判断条件。

哇塞,莫非我主角光环附身了!

我们也可以在这里绑定一个返回对象的**计算属性**。这是一个常用且强大的模式。

指的就是这种用法(个人猜测)!

最后讲一讲利用 v-bind 绑定style属性!

可能大家会很奇怪,既然都用 class 绑定了,何必需要 style 属性再来搅动风云呢?

因为绑定 style 属性居然可以 自动添加样式前缀

什么?我没听错吧,真的吗?这么666的功能吗?

让我来测试一下!必须找个浏览器兼容性不是很好的属性,就选 flex 吧!

    <div id="vue_demo5" :style="style">
        {{ content }}
    </div>
    <script>
        var demo5 = new Vue({
            el: '#vue_demo5',
            data: {
                content: "css 自动添加前缀",
                style: {
                    display: 'flex'
                }
            }
        })
    </script>

莫非我手头的浏览器都太新了,没有一点点变化,0.0。。有兴趣的朋友可以自己试试!

2.结语

不提我的惰性导致blog迟迟不写了,讲一些这个礼拜发生的事情吧,生活,学习,工作都有!

1、移动端图片压缩,拍照图片(不论怎么拿着相机拍的)调整为正确的方向!

之前也一直在使用这个工具,兼容性超过一大批百度到的压缩js插件。
think2011编写维护的localResizeIMG

不过iPhone4S 6.2.1系统有个bug,我用自己的思路改了改,至少在我的工程里是好用的
iPhone4S 拍照后预览图片有黑边的bug

题外话,这个js库的最大问题在于内存占用有点高,低端机在webview中可能会在此功能上闪退,我曾试过百度的webuploader,好像在这块处理的比较好。
但是代码有点多,分散在各个模块,我没有研究透,有兴趣的小伙伴可以自己看看!

2、react

公司里决定开始使用react,听到这个消息,我十分开心。这代表前端还是在公司中在持续发展的!

有位大哥分享了react的初学经验,混合讲了一些工程化工具的使用,如webpack。

但是既然我选择了Vue.js就好好的把Vue看完吧。

原文有误:
毕竟这两个东西的思想还是不太一致的,虽然都是MVVM框架!(react不是MVVM框架)

谢谢@阿炎

更正为:
react是一个专注于view层实现、构建组件化UIjs库,他可以搭配FluxAngularJSBackbone.js 等来实现一个完整的MVC或者MVVM框架的应用。

有些文章提到Flux并不是一种框架,而是一种模式。这块我自己也没理解清楚,请大家自己甄别!

3、关于生活

这周有个北漂盆友失联了,虽然最后发现是一个乌龙(仅仅是手机很多天没开机)。

但是真的,真的给我很大的触动。

我原来以为一个礼拜不打一个电话也没什么,但是知道他妈妈坐飞机过来找他,各种着急,报警,找人!

最关心你的永远是他们,一定要和家里常联系!

4、打气的话

人心其实很脆弱,所以我们要经常哄哄它,经常把手放在心脏旁,对自己说:Aai izz well,Aai izz well!

非常感谢小伙伴们看完文章!谢谢你们的支持,我会继续努力的!

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

推荐阅读更多精彩内容