计算属性和过滤器

1.methods和computed的区别

如以下代码:computed1.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>计算</title>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<button type="button" @click="show1()">调用methods方法点击</button>
<button type="button" @click="show2()">调用computer方法点击</button>
</div>
<script type="text/javascript">
/* 实例化一个Vue对象 /
var app = new Vue({
el: '#app',
data: {
name1:'methods',
name2:'computed'
},
methods:{
show1:function(){
/
console.log(this.name1); */
alert(this.name1);
}
},
computed:{
show2:function(){
alert(this.name2);
}
}
})
</script>
</body>
</html>

运行结果:
7.png

2.购物车:computed.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Vue.js computed练习——计算购物车总价</title>
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<style type="text/css">

        header{
            background: #FF7F50;
            width: 100%;
            height: 120px;
            color: #EEEEEE;
            left: 20px;
        }
        .container{
            left: 10px;
            position: relative;
            top: -20px;
            display: flex;
            flex-direction: column;
        }
        .item{
            display: flex;
            border: 1px solid #008000;
            border-radius: 10px;
            width: 85%;
            height: 50px;
            margin-bottom: 10px;
            /* 垂直方向居中 */
            align-items: center;
            /* 水平方向居中 */
            /* justify-content: center; */
            /* 内边距 */
            padding-left: 10px;
            padding-right: 10px;
            background: #EEEEEE;
        }
        .item-id{
            flex: 1 1 20%;
        }
        .item-name{
            flex: 1 1 20%;
        }
        .item-price{
            flex: 1 1 20%;
        }
        .item-count{
            flex: 1 1 20%;
        }
        .goods-count{
            width: 15px;
            text-align: center;
        }
        .accounts{
            display: flex;
            position: absolute;
            background: #FF7F50;
            width: 60px;
            height: 40px;
            /* 垂直方向居中 */
            align-items: center;
            border: 1px #008000;
            border-radius: 10px;
            left: 270px;
            top: 220px;
            outline:none;
            justify-content: center;
        }
        .totle{
            position: relative;
            top: -55px;
            left: 100px;
        }
        #photo{
            position: relative;
            width: 40px;
            height: 40px;
            left: 15px; 
        }
        .settlement {
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        .btn {
            width: 100px;
            height: 40px;
            background-color: #FF5000;
            border-radius: 10px;
            border: none;
            outline: none;
            color: #FFF;
            font-size: 16px;
        }
    </style>
</head>
<body>
    <header>
        <h3>购物车</h3>
        <p>共3件宝贝</p>
    </header>
    <!-- vue-app的根容器 -->
    <div id="app">
        <div class="container">
            <div class="item" v-for="goods in goodsList">
                <div class="item-id">
                    {{goods.id}}
                    <img :src="goods.photo" id="photo"/>
                </div>
                <div class="item-name">
                    {{goods.name}}
                </div>
                <div class="item-price">
                    {{goods.price}}
                </div>
                <div class="item-count">
                    <!--  :disabled="goods.count===0"减到0不能再减了-->
                    <button type="button" @click="goods.count-=1" :disabled="goods.count===0">-</button>
                    <input type="text" v-model="goods.count" class="goods-count"/>
                    <button type="button" @click="goods.count+=1">+</button>
                </div>
            </div>
            <hr >
            <!-- <h3>Total price:</h3>
            <p class="totle">¥{{totalPrice}}</p>
            <button class="accounts">结算</button> -->
            <div class="settlement">
                <h3>总价:¥{{totalPrice}}</h3>
                <button type="button" class="btn" @click="settlement()">结算</button>
            </div>
            <div class="result" v-if="show">
                你购买了{{settlement}}件商品,需要支付总价为:{{totalPrice}}元
            </div>
        </div>
    </div>
    <script type="text/javascript">
        // 实例化一个vue对象
        var app=new Vue({
            el:'#app',
            data:{
                goodsList:[
                    {
                        id:1,
                        name:'iphone 8',
                        price:6000,
                        count:1,
                        photo:'img/xphone.jpg'
                    },
                    {
                        id:2,
                        name:'iphone X',
                        price:7000,
                        count:2,
                        photo:'img/iphone2.jpg'
                    },
                    {
                        id:3,
                        name:'iphone XS Max',
                        price:8000,
                        count:1,
                        photo:'img/iphone3.jpg'
                    }
                ],
                show:false
            },
            methods:{
            },
            computed:{
                totalPrice:function(){
                    var totalPrice = 0;
                    var len=this.goodsList.length;
                    for(var i=0;i<len;i++){
                        totalPrice +=this.goodsList[i].price*this.goodsList[i].count;
                    }
                    return totalPrice;
            },
                    settlement: function() {
                    this.show = true;
                    var totalCount = 0;
                    var len = this.goodsList.length;
                    for (var i = 0; i < len; i++) {
                        totalCount += this.goodsList[i].count;
                    }
                    return totalCount;
                }
            } 
        })
    </script>
</body>

</html>

运行结果:


8.png

3.搜索按钮进行页面搜索:computed.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Vue.js computed练习-搜索页面的实现</title>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<style type="text/css">
.container {
width: 90%;
margin: 0 auto;
}

        .input-box {
            width: 50%;
            height: 25px;
            margin-bottom: 10px;
        }

        .item {
            display: flex;
            height: 100px;
            border: 1px solid #eee;
            border-radius: 8px;
            margin-bottom: 8px;
        }

        .item-title {
            flex: 1 1 80%;
            color: #00FFFF;
        }

        .item-thumbnail {
            flex: 1 1 20%;
        }

        .item-thumbnail img {
            width: 100%;
            height: 100%;
        }

        a {
            text-decoration: none;
        }

        a:link {
            color: #8E8E8E;
            text-decoration: underline;
        }

        a:visited {
            color: #008000;
            text-decoration: none;
        }

        a:hover {
            color: #0000FF;
            text-decoration: none;
        }

        a:active {
            color: #FF7F50;
            text-decoration: none;
        }

        .search {
            position: relative;
            top: -41px;
            width: 60px;
            height: 32px;
            background: #7FFF00;
            left: 50%;
            margin-bottom: 10px;
            /* 垂直方向居中 */
            align-items: center;
            display: flex;
            border: 1px solid #DDDDDD;
            outline: none;
        }
    </style>
</head>
<body>
    <div id="app">
        <div class="container">
            <input type="text" v-model="searchString" placeholder="请输入" class="input-box" />

            <button class="search" @click="handleClick()">搜索</button>

            <div class="item" v-for="article in filteredArticles" v-show="show">

                <a :href="article.url" class="item-title">
                    {{article.title}}
                </a>
                <div class="item-thumbnail">
                    <img :src="article.image">
                </div>
            </div>
        </div>
    </div>
    <script type="text/javascript">
        var app = new Vue({
            el: '#app',
            data: {
                searchString: "",
                show: false,
                // 数据模型
                articles: [{
                        "title": "堪称神器的3款在线工具,你一定用得上!",
                        "url": "https://www.jianshu.com/p/e83e7999346b",
                        "image": "https://upload-images.jianshu.io/upload_images/11438996-56b25f32c9307b4b?imageMogr2/auto-orient/strip%7CimageView2/2/w/640/format/webp"
                    },
                    {
                        "title": "经典面试题:从 URL 输入到页面展现到底发生什么?",
                        "url": "https://www.jianshu.com/p/45ba3e0d0c7e",
                        "image": "https://upload-images.jianshu.io/upload_images/3973862-d90954249a6f6ccd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp"
                    },
                    {
                        "title": "如何免翻墙使用谷歌搜索和Chrome应用商店",
                        "url": "https://www.jianshu.com/p/484f8e6c88f6",
                        "image": "https://upload-images.jianshu.io/upload_images/858154-015a4b083685a3d1.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/800/format/webp"
                    },
                    {
                        "title": "四款前所未有好用的黑科技APP,绝对的良心实用,赶紧告诉家人",
                        "url": "https://www.jianshu.com/p/2aec84d269fe",
                        "image": "https://upload-images.jianshu.io/upload_images/16042993-168b2cb17fd7ec0c?imageMogr2/auto-orient/strip%7CimageView2/2/w/640/format/webp"
                    },
                    {
                        "title": "坚持学英语的方法有哪些",
                        "url": "https://www.jianshu.com/p/0a6a61b0933c",
                        "image": "https://upload-images.jianshu.io/upload_images/3525704-c7293758fc59e56b.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/960/format/webp"
                    }
                ]
            },
            computed: {
                // 计算函数,匹配搜索
                filteredArticles: function() {
                    var articles_array = this.articles,
                        searchString = this.searchString;
                    //搜索关键词为空,则返回原始数据集
                    if (!searchString) {
                        return articles_array;
                    }
                    //搜索关键词去除无用空格,转换为小写
                    searchString = searchString.trim().toLowerCase();
                    //过滤数组中每个元素,如果
                    articles_array = articles_array.filter(function(item) {
                        if (item.title.toLowerCase().indexOf(searchString) !== -1) {
                            return item;
                        }
                    })
                    // 返回转化后的数组
                    return articles_array;
                }
            },
            methods: {
                handleClick: function() {
                    this.show = true;
                }
            },
        })
    </script>
</body>

</html>

运行结果:


9.png

搜索按钮可以按,但是刚开始没有主页面,这个好像是一次性的。

form表单练习:form.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Vue.js表单练习</title>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<input v-model="message1" placeholder="编辑我……">
<p>输入内容是: {{ message1 }}</p>



<textarea v-model="message2" placeholder="多行文本输入……"></textarea>
<p>多行文本域内容是:{{ message2 }}</p>


<input type="checkbox" id="baidu" value="BAIDU" v-model="checkedNames">
<label for="baidu">百度</label>
<input type="checkbox" id="google" value="GOOGLE" v-model="checkedNames">
<label for="google">谷歌</label>
<input type="checkbox" id="tencent" value="TENTCENT" v-model="checkedNames">
<label for="tencent">腾讯</label>


<span>选择的值为: {{ checkedNames }}</span>


<label>你一共选了{{checkedNames.length}}个</label>


<input type="radio" id="male" value="male" v-model="picked">
<label for="male">男</label>


<input type="radio" id="female" value="female" v-model="picked">
<label for="female">女</label>


<span>选中值为: {{ picked }}</span>


<select v-model="selected" name="fruit">
<option value="">选择一个网站</option>
<option value="www.baidu.com">百度</option>
<option value="www.taobao.com">淘宝</option>
<option value="www.niit.edu.cn">南工院</option>
</select>


<p> 选择的网站是: {{selected}}</p>


<button type="button" @click="commit">提交</button>
<hr >
<h2>结果显示</h2>
<div class="result">
<p>姓名:{{message1}}</p>
<p>性别:{{picked}}</p>
<h3>爱好</h3>
<ul>
<li v-for="item in checkedNames">
{{item}}
</li>
</ul>
<p>班级:{{selected}}</p>
</div>
</div>

    <script type="text/javascript">
        var app = new Vue({
            el: '#app',
            data: {
                message1: 'Hello Vue',
                message2: 'Vue官方教程',
                checkedNames: [],
                picked: 'male',
                selected: ''
            },
            methods: {
                commit: function() {
                    alert(this.message1 + this.picked + this.selected);
                }
            }
        })
    </script>
</body>

</html>

运行结果:


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

推荐阅读更多精彩内容