Vue.js之组件嵌套小demo

时间:2021-07-20 10:11:45

Vue.js之组件嵌套的小demo项目

第一步:初始化一个wabpack项目,这里不在复述。
第二步:在components文件夹下新建Header.vue Footer.vue和Users.vue三个组件文件

  Header.vue文件:

 <!--1模板:html结构 -->
<template>
<header>
<h1>{{title}}</h1>
</header>
</template> <!--2行为:处理逻辑 -->
<script>
export default {
name: 'app-header',
data () {
return {
title:"Vue.js Demo"
}
}
}
</script> <!--3样式:解决样式 -->
<style scoped>
header{
background: pink;
padding: 10px;
}
h1{
color: #222;
text-align: center;
}
</style>

  Users.vue文件:

 <template>
<div class="users">
<ul>
<li v-for="user in users"
@click="user.show = !user.show">
<h2 >{{user.name}}</h2>
<h3 v-show="user.show">{{user.Position}}</h3>
</li>
</ul>
</div>
</template> <script>
export default {
name: 'users',
data () {
return {
users:[
{name:"Henry",Position:"Java工程师",show:false},
{name:"Lily",Position:"Java工程师",show:false},
{name:"KangKang",Position:"Java工程师",show:false},
{name:"Maria",Position:"Java工程师",show:false},
{name:"Sally",Position:"Java工程师",show:false},
{name:"Elinna",Position:"Java工程师",show:false}
]
}
}
}
</script> <style scoped>
users{
width: 100%;
max-width: 1200px;
margin:40px auto;
padding: 0 20px;
box-sizing: border-box;
}
ul{
display: flex; //所有li在一行
flex-wrap: wrap; //所有li在容器里,不会超出容器
list-style-type: none;
padding: 0; //去掉浏览器自带的padding值
}
li{
flex-grow: 1; //如果一行之有一个会撑满整行,如果有两个,两个撑满整行
flex-basis: 200px; //每一个li200px的宽度
text-align: center;
padding: 30px;
border: 1px solid #666;
margin: 10px;
}
</style>

  Footer.vue文件:

 <template>
<footer>
<p>{{copyright}}</p>
</footer>
</template> <script>
export default {
data () {
return {
copyright:"Copyright 2018 Vue Demo" }
}
}
</script> <style scoped>
footer{
background: #666;
padding: 6px;
}
footer p{
color: pink;
text-align: center;
}
</style>

第三步:编写App.vue文件:在此文件中要在script中通过import引用刚才编写的三个组件,然后通过组件的别名使用组件。

App.vue文件:项目入口文件中引入的组件

 <!--模板-->
<template>
<div id="app">
<app-header></app-header>
<users></users>
<app-footer></app-footer>
</div>
</template> <!--行为-->
<script>
//局部注册组件
import Users from './components/Users'
import Header from './components/Header'
import Footer from './components/Footer' export default {
name: 'App',
components:{
"users":Users,
"app-header":Header,
"app-footer":Footer
}
}
</script> <!--样式-->
<style >
</style>

html文件:项目的入口文件

 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>vue-playlist</title>
</head>
<body>
<div id="app"></div>
</body>
</html>

main.js文件:项目的入口js文件

 import Vue from 'vue'
import App from './App' Vue.config.productionTip = false
new Vue({
el: '#app',
components: { App },
template: '<App/>'
})

  然后启动项目,就能看到生成一个组件嵌套形成的小demo

项目加载流程:
  index.html是入口文件,加载html时候会调用main.js文件,main.js文件会实例化vue组件App.vue,然后App.vue会把其他组件也加载进来,最后渲染整个页面。

Vue.js之组件嵌套小demo的更多相关文章

  1. Vue&period;js多重组件嵌套

    Vue.js多重组件嵌套 Vue.js中提供了非常棒的组件化思想,组件提高了代码的复用性.今天我们来实现一个形如 <app> <app-header></app-head ...

  2. Vue&period;js之组件嵌套

    Vue.js中组件嵌套有两种方式 第一种:注册全局组件 例如在components文件夹下新建一个User.vue组件,然后在main.js文件中注册全局组件 //注册全局组件 Vue.compone ...

  3. 【Vue课堂】Vue&period;js 父子组件之间通信的十种方式

    这篇文章介绍了Vue.js 父子组件之间通信的十种方式,不管是初学者还是已经在用 Vue 的开发者都会有所收获.无可否认,现在无论大厂还是小厂都已经用上了 Vue.js 框架,简单易上手不说,教程详尽 ...

  4. Vue&period;js 和 MVVM 的小细节

    Vue.js 和 MVVM 的小细节 转载 作者:流云诸葛 链接:www.cnblogs.com/lyzg/p/6067766.html MVVM 是Model-View-ViewModel 的缩写, ...

  5. 【Vue&period;js实战案例】- Vue&period;js递归组件实现组织架构树和选人功能

    大家好!先上图看看本次案例的整体效果. 浪奔,浪流,万里涛涛江水永不休.如果在jq时代来实这个功能简直有些噩梦了,但是自从前端思想发展到现在的以MVVM为主流的大背景下,来实现一个这样繁杂的功能简直不 ...

  6. Vue&period;js之组件传值

    Vue.js之组件传值 属性传值可以从父组件到子组件,也可以从子组件到父组件. 这里讲一下从父组件到子组件的传值 还以上次的demo为例,demo里有APP.vue是父组件,Header.vue,Us ...

  7. vue&period;js 同级组件之间的值传递方法&lpar;uni-app通用&rpar;

    vue.js 兄弟组件之间的值传递方法 https://blog.csdn.net/jingtian678/article/details/81634149

  8. Vue&period;js之组件(component)

    从结构上看,组件之于实例,就好比*之于汽车.从属性和方法来看,组件有实例的大部分方法,如果Vue实例是孙悟空,组件就好比实例的一个毫毛,变化多端却为Vue实例所用. 目录: 组件的注册 is的作用 ...

  9. 用Vue&period;js递归组件构建一个可折叠的树形菜单

    在Vue.js中一个递归组件调用的是其本身,如: Vue.component('recursive-component', {   template: `<!--Invoking myself! ...

随机推荐

  1. C&plus;&plus;对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  2. Mysql 获取年级每个班前十学生的信息

    select * from Table1 a where 10>(select count(*) from Table1 where ClsNo=a.ClsNo and Score>a.S ...

  3. Matrix的一些知识

    1.什么是ColorMatrix ColorMatrix是一个颜色矩阵,它定义了一个 4*5 的float[]类型的矩阵 颜色矩阵,而图像的 RGBA 值则存储在一个5*1的颜色分量矩阵C中 所以为了 ...

  4. acdream 1686 梦醒(时钟重合)

    Problem Description 娜娜离开了这个王国,走向远方,在旷野上,娜娜看到了一个大时钟,上面的时针分针秒针都在缓缓转动,那只挥着翅膀的天使又出现了,天使说:“外面天已经亮了,娜娜你别睡过 ...

  5. scanf&comma;sscanf利用format跳过干扰的空格

    scanf,sscanf利用format跳过干扰的空格 用了一点时间做读取配置部分的代码,希望一次记录上读取N个数据, 希望读取的格式就是一个IP地址加上端口号,希望把IP地址读取到4个短整数里面,端 ...

  6. android 开源框架推荐

    同事整理的 android 开源框架,个个都堪称经典.32 个赞! 1.volley 项目地址 https://github.com/smanikandan14/Volley-demo (1)  JS ...

  7. Qt学习之路&lpar;49&rpar;&colon; 通用算法

    今天开始的部分是关于Qt提供的一些通用算法.这部分内容来自C++ GUI Programming with Qt 4, 2nd Edition.   <QtAlgorithms>提供了一系 ...

  8. jstl 保留两位小数

    简介:jstl保留两位小数实现方法在JSP开头导入以下标签:<%@tagliburi="http://java.sun.com/jsp/jstl/fmt"pre jstl 保 ...

  9. jQuery整理您的笔记----jQuery开始

    Jquery它是一种高速.简明的JavaScript相框,jQuery设计目标:Write Less,Do More(写更少的代码,做很多其他的事情). 一.Jquery框架优势: 1.轻量级 jQu ...

  10. 一个简易内存池(C&plus;&plus;)

    做这个内存池主要是为了完成一道面试题,题目在代码中. 代码 #include <iostream> #include<string> #include <list> ...