首页 > 其他分享 >vue-04

vue-04

时间:2022-10-30 18:55:24浏览次数:44  
标签:vue name 04 Vue template 组件 data

计算属性

1.computed--计算属性--只有涉及到计算属性中的变量发生变化 它才重新运算
2.不是计算属性--页面刷新就会变化

<body>
    <div id="app">
        <input type="text" v-model="name">
        {{ handleUpper() }}
        <input type="text" v-model="name1">
        {{ handleDown }}
    </div>
</body>
<script>
    new Vue({
        el:'#app',
        data:{
            name: '',
            name1:''
        },
        methods:{
            handleUpper(){
                console.log('我执行了111')
                return this.name.slice(0, 1).toUpperCase() + this.name.slice(1)
            },
        },
          computed:{
                handleDown(){
                    console.log('我执行了222')
                    return this.name1.slice(0, 1).toUpperCase() + this.name1.slice(1)
                }
            }
    })
</script>
3.案例--计算属性写过滤
<body>
<div class="app">
    <p><input type="text" v-model="search" placeholder="请输入内容"></p>
    <p v-for="item in newList">{{ item }}</p>
</div>
</body>
<script>
    var vm=new Vue({
        el: '.app',
        data: {
            search: '',
            slist: [
                a,
                ab,
                cc,
                dc,
                beds,
                asdc
            ],
        },
        computed: {
            newList() {
                return this.slist.filter(item => {
                    return item.indexOf(this.search) >= 0
                })
            }
        }
    })
</script>

监听属性

1.watch--监听一个属性的变化,只要它发生变化,就执行一个函数
2.代码:

<body>
<div id="app">
    <button @click="type='首页'">首页</button>
    <button @click="type='商品页'">商品页</button>
    <button @click="type='购物车'">购物车</button>
    <br>
    {{ type }}
</div>
</body>
<script>
    new Vue({
        el:'#app',
        data:{
            type:'首页'
        },
        watch:{
            type(val){
                console.log(val)
            }
        }
    })
</script>

组件介绍和定义

1.定义组件 ()
全局组件:全局可以使用,可以用在任意其它组件中
局部组件:局部组件只能在定义的位置(组件中)使用
1.1 定义全局组件 (必须在一个标签),组件有自己的数据,方法,生周期.....
1.2 定义局部组件:
2.代码

<body>
<div id="app">
<h1>全局组件</h1>
<child></child>
<li></li>

</div>
</body>
<script>
//全局组件
    var obj= {
        template: `
        <div>
            <button>后退</button>
            {{ title }}
            <button @click="handleClick">前进</button>
        </div>`,
        data(){
            return{title:'标题'
        }},
        methods:{
            handleClick(){
                alert('前进')
            }
        }
    }
    Vue.component('child', obj)
//局部组件
    var lili = {
        template: `
        <div>
        <h1>我是tom组件</h1>
        {{ name }}
        <child1></child1>
        <child></child>
        </div>
        `,
        data(){
            return{
                name:'tom'
            }
        },

    }
    new Vue({
    el:'#app',
    data:{

    },
    component:{
        lili
    }
    })
</script>
</html>

父子通信

父传子

1.父传子
自定义属性:myname
在组件中渲染自定义属性名
2.代码:

  props:['myname',]完成父传子通信
<body>
    <div id="app">
        <lili :myname="name"></lili>
    </div>
</body>
<script>
    var lili={
        template:`
        <div>
        <h1>我是lili组件</h1>
            {{ myname }}
        </div>
        `,
        props:['myname',]
    }
    new Vue({
        el:'#app',
        data:{
            name:'kevin'
        },
        components:{
            lili
        }
    })
</script>

子传父

1.子传父
子组件在父组件中自定义事件(需要传参数):<lili @myevent="handleEvent">
子组件中执行点击事件:里面传自定义事件名与传的参数
methods:{
handleClick(){
this.$emit('myevent',this.name)
}},
父组件中执行自定义事件:
methods: {
handleEvent(name){
this.name=name
}},
2.代码:

<body>
<div id="app">
    <h1>父子通信</h1>
    {{ name }}
        <lili @myevent="handleEvent"></lili>
</div>

</body>
<script>
    var lili={
        template:`
            <div>
                <h1>子组件lili</h1>
                <input type="text" v-model="name">{{ name }}
                <button @click="handleClick">提交获取子组件数据</button>
            </div>
        `,
        data(){
            return{
                name:''
            }
        },
         methods:{
            handleClick(){
            this.$emit('myevent',this.name)
            }
        },
    }
    new Vue({
        el:'#app',
        data:{
            name:'kevin'
        },
        methods: {
            handleEvent(name){
            this.name=name
            }
        },
        components:{
            lili
        }
    })
</script>

ref属性

1.ref属性放在普通标签上:相当于dom操作
普通标签:--->{{ name }}
通过this.$refs.inputout(自定义ref属性名)获取原生dom对象
通过this.$refs.inputout.value='222'改值
2.ref属性放在组件上:
通过this.$refs.inputoutter(子组件中定义的ref属性名)获取vc对象(组件对象)
可以之间使用组件对象上的方法和属性---》子的数据给了父亲
父组件有个方法执行,需要传参数,传入子组件的数据---》子的数据给了父亲
-拿到子对象之间使用父中的数据修改----》父传子
3.代码:

<body>
    <div id="app">
        <h1>父组件</h1>
        <input type="text" ref="inputout" v-model="name">--->{{ name }}  //ref属性放在普通标签
        <button @click="handleClick">提交</button>
        <lili ref="inputoutter"></lili>  //ref属性放在组件上
    </div>
</body>
<script>
    var lili={
        template:`
            <div>
                <button>后退</button>
                    <span>点我</span>
                    {{ name }}---{{ age }}
                <button @click="handleClick">前进</button>
            </div>
        `,
        data(){
            return{
                name:'tom',
                age:18
            }
        },
        methods: {
            handleClick(){
                alert('123')
                    }
        }
    }
    new Vue({
        el:'#app',
        data:{
            name:'lili'
        },
        methods:{
            handleClick(){
                console.log(this.$refs)
                this.$refs.inputout.value='222' //原生dom操作
                this.$refs.inputoutter.name='tom'   //父组件修改子组件数据
                this.name=this.$refs.inputoutter.name  //子组件修改父组件
            }
        },
        components:{
            lili
        }
    })
</script>
  

动态组件

1.通过动态绑定组件完成组件间的切换
2.代码:

<body>
<div id="app">
    <div>
        <span @click="type='home'">首页</span>
        <span @click="type='goods'">商品</span>
        <span @click="type='car'">购物车</span>
    </div>
{#    <home></home>     //可以通过v-if做判断显示#}
{#    <goods></goods>#}
{#    <car></car>#}
    <div>
        <component :is="type"></component>
    </div>
</div>
</body>
<script>
    Vue.component('home', {
        template: `
        <div>
            <span>首页</span>
        </div>`,
    })
     Vue.component('goods',{
        template:`
        <span>商品</span>
        `}
     )
     Vue.component('car',{
        template:`
        <span>购物车</span>
        `}
     )
    new Vue({
        el:'#app',
        data:{
            type:'home'
        }
    })
</script>

keep-alive

1.keep-alive标签--保留组件数据不会销毁
2.代码:

<body>
<div id="app">
    <div>
        <span @click="type='home'">首页</span>
        <span @click="type='goods'">商品</span>
        <span @click="type='car'">购物车</span>
    </div>
    <div>
        <keep-alive>
        <component :is="type"></component>
            </keep-alive>
    </div>
</div>
</body>
<script>
    Vue.component('home',{
        template:`
        <div>
            <h1>首页</h1>
        </div>
        `
    })
    Vue.component('goods',{
        template:`
        <div>
            <h1>商品</h1>
            <input type="text" placeholder="请输入需要搜索的内容"><button>搜索</button>
        </div>
        `
    })
    Vue.component('car',{
        template:`
        <div>
            <h1>购物车</h1>
        </div>
        `
    })
    new Vue({
        el:'#app',
        data:{
            type:'home'
        }
    })
</script>

插槽

1.通过在组件中留位置
2.具名插槽--多个插槽
在组件中添加数据
3.代码:

<body>
<div id="app">
    <home>
        <img src="https://t13.baidu.com/it/u=2296451345,460589639&fm=224&app=112&size=w931&n=0&f=JPEG&fmt=auto?sec=1667235600&t=7ae0228c284af79b220539e31d60389d" alt="">
    </home>
</div>
</body>
<script>
    Vue.component('home',{
        template:`
        <div>
            <h1>首页</h1>
        <hr>
        <slot>
        </slot>
        </div>
        `

    })
    new Vue({
        el:'#app',
        data:{
            
        }
    })
</script>

vue-cli

1.vue的脚手架:快速帮我们创建出vue的项目
2.vue2 和 vue3 
  vue-cli可以创建vue2和vue3的项目    webpack构建工具
  Vite:新一代构建工具
  vue3上,推荐使用ts写  js
3.先安装nodejs 后端语言---》语法就是js的语法
  js运行在浏览器中,浏览器中有它的解释器环境
  不能运行在操作系统之上,把chrom浏览器的v8引擎,把它安装在操作系统上
  c语言写了内置库:文件操作,网络操作
  官网:https://nodejs.org/zh-cn/download/ ,下载,一路下一步
  安装完会释放两个命令(在环境变量中,任意路径都能敲这俩命令)
    	-node      python3
        -npm        pip
        -cnpm      等同于pip ,只是下模块,直接取淘宝镜像站下载,速度快
4.安装vue-cli ,通过脚手架创建vue项目 (django--->django项目--->django-admin)
 	安装vue-cli:cnpm install -g @vue/cli
    -只要装成功,又会多出一个可执行文件  vue
5.npm 下载时候,去国外,速度慢,使用国内镜像
  淘宝做了一个cnpm可执行文件,用来替换npm,以后所有使用npm的地方都换成cnpm即可
 安装cnpm:npm install -g cnpm --registry=https://registry.npm.taobao.org
6.创建vue项目:vue create myfirstvue
7.ide的选择(vscode,webstorm:jetbrains公司的,跟pycharm一家的,使用习惯一样)
  选择使用pycharm+vue插件 开发vue项目
  使用pycharm打开vue项目
8.运行vue项目
  方式一:在命令行中敲:npm run serve
  方式二:在pycharm中点击绿色箭头运行
9.安装axios:cnpm install axios


作业

1.获取所有图书接口drf写,处理跨域(响应头)前端vue项目首页,只要加载好就获取所有图书v-for循环显示在页面上

1.获取所有图书接口drf代码:
class BookViews(GenericAPIView):
    queryset = Book.objects.all()
    serializer_class = BookSerializer

    def get(self, request):
        book_list = self.get_queryset()
        ser = self.get_serializer(instance=book_list, many=True)
        return Response(ser.data, headers={'Access-Control-Allow-Origin': '*'})
2.vue显示:
<template>
  <div class="home">
<div class="bs-example" data-example-id="striped-table">
    <table class="table table-striped">
      <thead>
        <tr>
          <th>序号</th>
          <th>书名</th>
          <th>价格</th>
          <th>出版社</th>
        </tr>
      </thead>
      <tbody>
        <tr v-for="book in res">
          <th>{{ book.id }}</th>
          <td>{{ book.name }}</td>
          <td>{{ book.price }}</td>
          <td>{{ book.publish }}</td>
        </tr>
      </tbody>
    </table>
  </div>
  </div>
</template>
<script>
import axios from 'axios'
export default {
  name: 'HomeView',
  data(){
      return{res:''}
  },
  created() {
    axios('http://127.0.0.1:8000/book/').then(res=>{
      console.log(res)
      this.res=res.data
      console.log(this.res)
    })
  }
}
</script>

标签:vue,name,04,Vue,template,组件,data
From: https://www.cnblogs.com/040714zq/p/16841916.html

相关文章

  • 【2022.10.28】Vue基础学习(4)
    内容概括1.计算属性重写过滤案例2.监听属性3.组件介绍和定义4.父子通信之父传子5.父子通信之子传父6.ref属性7.动态组件keep-alive8.插槽9.vue-cli内容......
  • 创建 Vue 实例的几种方法
    创建Vue实例的几种方法1、html文件中<body><divid="root":class="{cur:1===1}">我们</div><scriptsrc="../js/vue.js"></script><script>constvm=new......
  • 第121期:一次成功的基于vue3和ts的CodeReview
    封面图CodeReview现场背景当前项目已经接入了公司自研的前端监控平台,已经有能力对线上运行的各个项目进行错误监控,并且可以统计相关报错信息及日志。对于报错问题的修复前段......
  • vue echarts radar 雷达图
    很多项目中经常会用echarts,研究下雷达图,画个简单的,没有做深度研究html:<divid="app"><divid="main"class="echarts":style="{wi......
  • vue 组件
    组件计算属性如果{{函数()}},每次页面刷新,函数都会重新执行函数就是当属性使用,用于缓存通过计算属性实现输入首字母大写<!DOCTYPEhtml><htmllang="en"><head>......
  • Vue复刻华为官网(三)
     1底部列表1.1思路如上图,这整个的大盒子,又可以被分为上中下三个小盒子,上、下盒子都被分为左右两个小盒子。这部分的难点主要体现在搜索栏上,特别是搜索栏聚焦的时候,会有一......
  • SSM框架+VUE+Mysql实现的疫苗预约接种管理系统(功能包含分角色,登录/注册、疫苗管理、接
    (博客目录)SSM框架+VUE+Mysql实现的疫苗预约接种管理系统本系统为了解决疫苗线下预约场景复杂,预约难等一系列问题,开发了疫苗接种管理平台,很好的提供了疫苗的管理和接种整......
  • vue3 reactive函数
    reactive的用法与的用法相似,也是将数据变成响应式数据,当数据发生变化时也会自动更新。不同的是用于基本数据类型,而是用于复杂数据类型,比如对象和数组例如:定义一个对象类型......
  • Ubuntu20.04下安装MySql8
    mysql下载到https://dev.mysql.com/downloads/mysql/,如果无法通过ftp上传到云服务器,可以通过如下命令在服务器端下载wgethttps://dev.mysql.com/get/Downloads/MySQL-......
  • Vuex知识汇总
    vuex的五大核心state:存放公共数据/状态;getter:vuex独有的计算属性,获取state⾥⾯的状态,并且可以对数据进⾏处理之后在返回;mutations:修改state⾥⾯的数据,只能进⾏同步的操作......