vue day01

一、前端发展介绍

    1. HTML(5)、CSS(3)、JavaScript(ES5、ES6、ES13):编写一个个的页面 -> 给后端(PHP、Python、Go、Java) -> 后端嵌入模板语法 ->
     后端渲染完数据 -> 返回数据给前端 -> 在浏览器中查看
        - ECMA标准
        - JavaScript = ECMA+bom+dom
    2. Ajax的出现 -> 后台发送异步请求,Render+Ajax混合
    3. 单用Ajax(加载数据,DOM渲染页面):前后端分离的雏形
    4. Augular框架的出现(1个JS框架):出现了“前端工程化”的概念(前后端也是1个工程、1个项目)
    5. React、Vue框架:当下最火的2个前端框架(Vue:国人喜欢用,React:外国人喜欢用)
    6. 移动开发(Android+IOS)+Web(Web+微信小程序+支付宝小程序) + 桌面开发(Windows桌面):前端 -> 大前端
    7. 一套代码在各个平台运行(大前端):谷歌Flutter(Dart语言:和Java很像)可以运行在IOS、Android、PC端
    8. 在vue框架的基础上 unni-app:一套编码 编导10各平台
    9. vue:2.X 3.X
        -ts:typescript
        -less
    10. 在不久的将来,前端框架可能会一统天下
    11. 主流:vue、react、uni-app
            -typescript

二、Vue的快速使用

    1、Vue 是一套用于构建用户界面的渐进式框架

      - 渐进式就是一点一点使用它,只用一部分,也可以整个工程都使用它

    2、开发Vue,有一款编辑器

      - vscode:微软 轻量级编辑器,免费

      - vim:装插件,搞得花里胡哨,如果你能够开发代码则可以免费试用这款编辑器

    3、Jetbrains:IDEA(JAVA),Pycharm,Goland,phpStron,webstorm  收费   吃内存(Java 开发)

    4、AndroidStadio:免费,谷歌买了Jetbrains授权+ADT

        - sun:java---->后来被甲骨文收购了---->oracle  jdk  openjdk  毕昇jdk

    5、Pycharm + 插件  开发vue  使用起来跟 webstorm一样

        - 把vue的源码下载到本地

 

    6、M-V-VM思想

        - MTV【model view templete】:前沿的软件架构模式,高内聚低耦合易于开发,提高开发效率django框架基于这种架构

        - MVC【model view controller 控制器】:大部分开发语言中都有MVC框架,核心思想是解耦,能降低各功能模块之间的耦合性,方便变更后端框架一般基于这种架构

        - MVVM【model view viewmodel】:MVC的改进版,前端框架  vue

        - MVP:移动端

  MTV、MVC、MVVM具体介绍:https://www.jianshu.com/p/fba4da2f22df

    7、组件化开发、单页面开发

      - 组件化开发:有自己独立的html,css,js

      - 单页面应用(SPA)

        -只有一个html页面

view快速使用的代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
    <h1>vue的快速使用</h1>
    <p>名字:{{name}}</p>  //data里面的name替换掉这个name
    <p>年龄:{{age}}</p>   // data里面的age替换掉这里的age
</div>
</body>
<script>
    //在这里面使用vue
    // 引入vue后,会有vue的构造函数,(如何使用构造函数呢,如下代码)传入 配置项---》对象(一堆key_value,key_value)
    // 页面中id为app的div就被vue托管了(vue管这个id为app的div了),在div中就可以写vue的语法,指令
    // js中字典叫对象,列表叫数组
    var vm = new Vue({    // 类似于类实例化一个对象,然后传一个对象(字典)
        el: "#app",  // 配置项的k值叫el、data
        data: {
            name: 'wyn',
            age: 19
        },
    })

</script>
</html>

但最神奇的是下面这个情况:数据改则页面改(好处是不需要dom,直接改变量的值就行了,非常方便)

三、插值语法

   被vue托管的标签中可以写 {{ }}  大括号里面可以写:变量、js简单的表达式、函数(函数返回值是什么,就渲染出什么)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
    <h1>vue插值渲染变量</h1>
    <p>名字:{{name}}</p>
    <p>年龄:{{age}}</p>
    <p>爱好:{{hobby}}</p>
    <p>第0个爱好:{{hobby[0]}}</p>
    <p>wife:{{wife}}</p>

    <p>wife:{{wife['name']}}</p>
    <p>wife:{{wife.age}}</p>
    <p>标签:{{a}}</p>
    <h1>vue插值渲染简单表达式</h1>
    <p>{{10 > 9 ? '大于' : '小于'}}</p>
    <p>{{age+1}}</p>


</div>
</body>
<script>
    var vm = new Vue({
        el: "#app",
        data: {
            name: 'wyn',
            age: 19,
            hobby: ['篮球', '足球', '乒乓球'],
            wife: {name: '刘亦菲', age: 35},
            a: '<a href="http://www.baidu.com"></a>'
        },
    })
    // js中的三木运算符----》就是三元表达式
    // var a = 10 > 9 ? '大于':'小于'
    // 意思就是,如果a符合这个条件就是大于,不符合则为小于
</script>
</html>

四、指令系统之文本指令

 1、指令 : 写在【任意】标签上(a标签,p标签,div标签),以 v-xx 开头的,这种东西都是vue的指令

  2、文本指令

ps:由于v开头的指令在pycharm中不显示,所以我们需要找到settings中的Plugins【插件】去下载一个vue

    ①v-text:把变量渲染到标签中,如果之前有数据,覆盖掉

    ②v-html:如果是标签字符串,会把标签渲染到标签内

    ③v-show:控制标签的显示与隐藏,但是他是通过style的display控制的:style="display:none;"

    ④v-if:控制标签的显示与隐藏,但是他是通过dom的增加和删除标签

总体代码展示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
    <h1>文本指令 v-text</h1>
    <p v-text="name">林一</p>
    <h1>文本指令 v-html</h1>
    <p v-html="a"></p>
    <h1>文本指令 v-show</h1>
    <img v-show="show" src="https://p.qqan.com/up/2022-10/2022101983136292.jpg" alt="" width="300px" height="300px">
    <h1>文本指令 v-if</h1>
    <div v-if="b1">
        <a href="">点我看美女</a>
        <h3>美女</h3>
    </div>
</div>
</body>
<script>
    var vm = new Vue({
        el: "#app",
        data: {
            name: 'wyn',
            a: '<a href="http://www.baidu.com">点我</a>',
            show:true,
            b1:true
        }
    })
</script>
</html>

-----v-text的数据覆盖现象-----

-----v-show通过style="display:none" 来控制图片显示与隐藏现象-----

-----v-if标签的显示与隐藏的展示-----

五、指令系统之事件指令


    // es5中对象写法
     var obj={'name':'lqz','age':19}
     var obj={name:'lqz',age:19}
    // es6中对象写法
    var name = 'lqz'
    var age = 19
    // var obj={name:name,age:age}
    var obj = {
        name, age, handleClick() {
        }
    }

代码编写:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>

<div id="app">

    <h1>事件指令</h1>

    <button v-on:click="handleShow">点我显示消失</button>
    <div v-if='show'>
        <img src="https://tva1.sinaimg.cn/large/00831rSTly1gd1u0jw182j30u00u043b.jpg" alt="" width="300px"
             height="300px">

    </div>
    <h1>事件指令函数带参数</h1>
    <button @click="handleClick">函数需要参数,但是没传,默认会把event事件传入</button>
    <br>
    <button @click="handleClick1('lqz')">函数需要参数,但是传值了</button>  // handleClick1括号内可以传数字,字符串,变量
    <br>
    <button @click="handleClick2('lqz')">函数需要3参数,但是传了1个</button>
    <br>
    <button @click="handleClick3($event,'lqz')">函数需要2参数,一个事件,一个字符串</button>  // 如果不传值,那么默认把事件传入,但是字符串为undefined,
                                                //如果只传字符串,那么字符串就给了事件,第二个参数还是undefined,所以js提供了一个$event


</div>


</body>
<script>
    var vm = new Vue({
        el: "#app",
        data: {
            show: true,
        },
        methods: {    // 一定得是methods
            // handleShow: function () {
            //     this 就是vm对象 vm.show就是this.show
            //     this.show = !this.show     ! 是取反的意思 如果原来的是true就会变成false,如果原来是false就会变成true
            // },
            //es6的语法,对象写法,以后都这样写
            handleShow() {
                // this 就是vm对象 vm.show
                this.show = !this.show
            },
            // 需要一个参数,但是没有传,会把事件传入
            handleClick(a) {
                console.log(a)
                alert('帅哥')
            },
            // 需要1个,传了一个,但是需要传数字,字符串,布尔,或变量
            handleClick1(name) {
                console.log(name)
            },
            // 需要3个参数,传了一个,没问题,后面俩都是 undefined(未定义的)
            handleClick2(a, b, c) {
                console.log(a)
                console.log(b)
                console.log(c)

            },
            handleClick3(event,name){
                console.log(event)
                console.log(name)

            }


        }
    })
    
</script>

</html>

六、指令系统之属性指令

  1、写在标签上的 name、class、href、src、id........属性

  2、v-bind:属性名='变量'

  3、简写成:

    v-bind:属性名='变量'  --->   :属性名=“变量”

实现从第一张图片换到第二张图片的功能,但是到了第二张照片的时候就结束了,因为写死了:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
    <h1>属性指令</h1>
    <button @click="handleClick">看美女</button>
    <br>
    <img v-bind:src="url" alt="" width="300px" height="300px">

</div>
</div>


</body>
<script>
    var vm = new Vue({
        el: "#app",
        data: {
            url: 'https://p.qqan.com/up/2022-10/20221018923191616.jpg',

        },
        methods: {
            handleClick() {
                this.url = 'https://p.qqan.com/up/2022-7/2022728920426303.jpg'
            },
            handleChange() {

            }

        }
    })
</script>
</html>

代码展示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>

<div id="app">

    <h1>属性指令</h1>
    <button @click="handleClick">点我看美女</button>
    <br>
    <img v-bind:src="url" alt="" width="300px" height="300px">  // 使用bind,src的括号里面可以加变量、表达式、函数
    <hr>
    <button @click="handleChange">点我换美女</button>
    <br>
    <img :src="img_url" alt="" width="300px" height="300px">
    <hr>
    <img :src="img_url2" alt="" width="300px" height="300px">
    <hr>

    <div :id="id_div">
        我是div
    </div>
</div>


</body>
<script>
    var vm = new Vue({
        el: "#app",
        data: {
            url: 'https://tva1.sinaimg.cn/large/00831rSTly1gd1u0jw182j30u00u043b.jpg',
            img_url: 'https://p.qqan.com/up/2022-8/202283919254843.jpg',
            img_url2: 'https://tva1.sinaimg.cn/large/00831rSTly1gd1u0jw182j30u00u043b.jpg',
            imgList: ['https://img2.woyaogexing.com/2022/10/23/af963193e9fb67ee!400x400.jpg',
                'https://img2.woyaogexing.com/2022/10/22/95afdd5cd39d556d!400x400.jpg',
                'https://img2.woyaogexing.com/2022/10/21/f06c65142fe50c19!400x400.jpg',
                'https://img2.woyaogexing.com/2022/10/20/c0135f7e74050a74!400x400.jpg',
                'https://img2.woyaogexing.com/2022/10/20/5972f09505ac681d!400x400.jpg'],
            id_div:'xxx'
        },
        methods: {
            handleClick() {
                this.url = 'https://p.qqan.com/up/2022-8/202283919254843.jpg'

            },
            handleChange() {
                // floor:只取整数部分
                //Math.random() 生成0--1直接的数字,小数
                var i = Math.floor(Math.random() * this.imgList.length)
                console.log(i)
                this.img_url = this.imgList[i]
            }
        },
    // 定时器功能,能够让照片像幻灯片一样自动播放
        mounted() {
            // 页面加载完,开启一个定时器,每隔3s干函数内容,函数里面在变化变量
            setInterval(() => {
                var i = Math.floor(Math.random() * this.imgList.length)
                this.img_url2 = this.imgList[i]
            }, 1000)
        }
    })


</script>

</html>

 

posted @ 2022-10-24 19:59  W-Y-N  阅读(33)  评论(0)    收藏  举报