vue_03 练习
1、有以下广告数据(实际数据命名可以略做调整)
ad_data = {
	tv: [
		{img: 'img/tv/001.png', title: 'tv1'},
		{img: 'img/tv/002.png', title: 'tv2'},
		{img: 'img/tv/003.png', title: 'tv3'},
		{img: 'img/tv/004.png', title: 'tv4'},
	],
	phone: [
		{img: 'img/phone/001.png', title: 'phone1'},
		{img: 'img/phone/002.png', title: 'phone2'},
		{img: 'img/phone/003.png', title: 'phone3'},
		{img: 'img/phone/004.png', title: 'phone4'},
	]
}
i) 有两个大标题,电视和手机,点击对应的标题,渲染对应的数据
ii) 一个字典作为一个显示单位,定义一个子组件进行渲染(涉及父子组件传参)
2、在第1题基础上,页面最下方有一个 h2 标签,用来渲染用户当前选择的广告(点击哪个广告就是选中哪个广告)
i)当没有点击任何广告,h2 标签显示:未选中任何广告
ii)当点击其中一个广告,如tv1,h2 标签显示:tv1被选中
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>作业</title>
    <style>
        body, h2 {
            margin: 0;
        }
        .wrap {
            width: 880px;
            margin: 0 auto;
        }
        .wrap:after {
            content: '';
            display: block;
            clear: both;
        }
        .box {
            width: 200px;
            border-radius: 10px;
            overflow: hidden;
            background-color: #eee;
            float: left;
            margin: 10px;
        }
        .box img {
            width: 100%;
            height: 240px;
        }
        .box h2 {
            text-align: center;
            font-weight: normal;
            font-size: 20px;
        }
        .nav, h2 {
            text-align: center;
        }
        .active {
            background-color: pink;
        }
    </style>
</head>
<body>
<div id="app">
    <div class="nav">
        <button @click="page = 'tv'" :class="{active: page === 'tv'}">tv</button>
        <button @click="page = 'phone'" :class="{active: page === 'phone'}">phone</button>
    </div>
    <div class="wrap" v-if="page === 'tv'">
        <tag v-for="tv in ad_data.tv" :ad="tv" :key="tv.title" @action="change_select"></tag>
    </div>
    <!-- v-for指令,需要给循环的标签或组件添加 key 属性,完成缓存的建立 -->
    <div class="wrap" v-else-if="page === 'phone'">
        <tag v-for="phone in ad_data.phone" :ad="phone" :key="phone.title" @action="change_select"></tag>
    </div>
    <h2 class="footer">{{ select_ad }}</h2>
</div>
</body>
<script src="js/vue.js"></script>
<script>
    ad_data = {
        tv: [
            {img: 'img/tv/001.jpg', title: 'tv1'},
            {img: 'img/tv/002.jpg', title: 'tv2'},
            {img: 'img/tv/003.jpg', title: 'tv3'},
            {img: 'img/tv/004.jpg', title: 'tv4'},
        ],
        phone: [
            {img: 'img/phone/100.jpg', title: 'phone1'},
            {img: 'img/phone/200.jpg', title: 'phone2'},
            {img: 'img/phone/300.jpg', title: 'phone3'},
            {img: 'img/phone/400.jpg', title: 'phone4'},
        ]
    };
    let tag = {
        props: ['ad'],
        template: `
            <div class="box" @click="send_ad(ad)">
                <img :src="ad.img" alt="">
                <h2>{{ ad.title }}</h2>
            </div>
        `,
        methods: {
            send_ad(ad) {
                this.$emit('action', ad);
            }
        }
    };
    new Vue({
        el: '#app',
        data: {
            ad_data,
            page: 'tv',
            select_ad: '未选中'
        },
        components: {
            tag,
        },
        methods: {
            change_select(ad) {
                // this.select_ad = ad.title + '被选中';
                this.select_ad = `${ad.title}被选中`;
            }
        }
    })
</script>
</html>
												
											vue_03 练习的更多相关文章
- vue_03总结
		
vue_03总结 1.组件: html.css.js的集合体 vue实例就代表组件 组件用template实例成员管理html结构,有且只有一个根标签 子组件可以复用,所以数据要组件化处理,data的 ...
 
随机推荐
- 大数据学习笔记【一】:Hadoop-3.1.2完全分布式环境搭建(Windows 10)
			
一.前言 Hadoop原理架构本人就不在此赘述了,可以自行百度,本文仅介绍Hadoop-3.1.2完全分布式环境搭建(本人使用三个虚拟机搭建). 首先,步骤: ① 准备安装包和工具: hadoop-3 ...
 - EasyUI datagrid 动态加载表头和数据
			
首先返回到页面的需要是JSON数据: 第一步: 遍历表头,插入到array中 for (var i = 0; i < jsonObj.title.length; i++) { //把返回的数据封 ...
 - 【计算机网络】-传输层-Internet传输协议-UDP
			
[计算机网络]-传输层-UDP 简介 Internet协议集支持一个无连接的传输协议,该协议称为用户数据报协议(UDP,UserDatagram Protocol) .UDP为应用程序提供了一-种无需 ...
 - 最长回文 HDU - 3068(马拉车算法)
			
Problem Description 给出一个只由小写英文字符a,b,c...y,z组成的字符串S,求S中最长回文串的长度. 回文就是正反读都是一样的字符串,如aba, abba等 Input 输入 ...
 - 剑指offer23:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。输出Yes OR No。
			
1 题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 2 思路和方法 二叉搜索树:二叉查找树(Bin ...
 - selenium登录慕课网
			
from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.s ...
 - 通过ImageReader进行图像裁剪时出现NoSuchElementException异常
			
首先放上最初的Image工具类 package util; import java.awt.Rectangle; import java.awt.image.BufferedImage; import ...
 - RSA加密,以及证书加密
			
简单的加密:https://blog.csdn.net/qq_32523587/article/details/79092364 生成证书:https://blog.csdn.net/u0121916 ...
 - javascript 构建模块化开发
			
在使用 sea.js .require.js . angular 的时候. 我们使用到 define . module(require) 的方式,定义模块,和依赖模块 下面给出 define 和 m ...
 - 怎样理解"不推荐不使用var的变量声明方式"这句话
			
答: 因为不使用var声明的变量不会被预解析, 如下: console.log(a); console.log(b); var a = 1; b = 2;