发表于: 2019-10-31 09:26:41

3 942


Vue与传统html的区别

1.文件类型变化

以前是.html文件,现在是.vue文件

2.文件内代码架构的变化

以前一个html大节点,里面有script和style节点;

现在叫vue单文件组件规范sfc

<template>  

    <view>  

    注意必须有一个view,且只能有一个根view。所有内容写在这个view下面。  

    </view>  

</template>  

<script>  

    export default {  

    }  

</script>  

<style>  

</style>

template是一级节点,用于写tag组件,script和style是并列的一级节点,也就是有3个一级节点。

3.外部文件引用方式变化

  

以前通过script src、link href引入外部的js和css;

现在是es6的写法,import引入外部的js模块(注意不是文件)或css模块。例:

<style>  

    @import "./common/uni.css";  

    .uni-hello-text{  

        color:#7A7E83;  

    }  

</style>


② 

vue支持组件导入,可以更方便的封装一个包括界面、js、样式的库。

如下是导入一个角标的组件库,详见

<template>  

    <view>  

        <uni-badge text="abc" :inverted="true"></uni-badge><!--3.使用组件-->  

    </view>  

</template>  

<script>  

    import uniBadge from "../../../components/uni-badge.vue";//1.导入组件  

    export default {  

        data() {  

            return {  

            }  

        },  

        components: {  

            uniBadge //2.注册组件  

        }  

    }  

</script>

如需要全局导入vue组件,即每个页面都可以直接使用而不用引用和注册的话,在项目根目录下的main.js里处理。

//main.js  

import pageHead from './components/page-head.vue' //导入  

Vue.component('page-head', pageHead) //注册。注册后在每个vue的page页面里可以直接使用<page-head></page-head>组件。

4.组件/标签的变化

js的变化

  • 以前的dom操作,改成vue的MVVM模式

现在前端趋势是去dom化,改用mvvm模式,更简洁的写法,大幅减少代码行数,同时差量渲染性能更好。

uni-app使用vue的数据绑定方式解决js和dom界面交互的问题。

如果你想改变某个dom元素的显示内容,比如一个view的显示文字:

以前是给view设id,然后js里通过选择器获取dom元素,进一步通过js进行赋值操作,修改dom元素的属性或值。

如下演示了一段代码,页面中有个显示的文字区和一个按钮,点击按钮后会修改文字区的值

<html>  

    <head>  

        <script type="text/javascript">  

            document.addEventListener("DOMContentLoaded",function () {  

                document.getElementById("spana").innerText="456"  

            })  

            function changetextvalue () {  

                document.getElementById("spana").innerText="789"  

            }  

        </script>  

    </head>  

    <body>  

        <span id="spana">123</span>  

        <button type="button" onclick="changetextvalue()">修改为789</button>  

    </body>  

</html>  

现在的做法,是vue的绑定模式,给这个dom元素绑定一个js变量,在script中修改js变量的值,dom会自动变化,页面会自动更新渲染

<template>  

    <view>  

        <text>{{textvalue}}</text><!-- 这里演示了组件值的绑定 -->  

        <button :type="buttontype" @click="changetextvalue()">修改为789</button><!-- 这里演示了属性和事件的绑定 -->  

    </view>  

</template>  

<script>  

    export default {  

        data() {  

            return {  

                textvalue:"123",  

                buttontype:"primary"  

            };  

        },  

        onLoad() {  

            this.textvalue="456"//这里修改textvalue的值,其实123都来不及显示就变成了456  

        },  

        methods: {  

            changetextvalue() {  

                this.textvalue="789"//这里修改textvalue的值,页面自动刷新为789  

            }  

        }  

    }  

</script>



返回列表 返回列表
评论

    分享到