• 技术文章 >web前端 >js教程

    jquery和vue对比实例分析

    小云云小云云2018-03-05 17:00:23原创853
    很多人说jquey和vue没有什么可比的,应该和Angular,React来比吧,我到觉得他们倒没有多大的可比性,都是基于mvvm思想设计的框架,无非就是实现的方式不一样,在不同场景下性能上会有一些差异。然而从jquery到vue或者说是到mvvm的转变则是一个思想想的转变,是将原有的直接操作dom的思想转变到操作数据上去,难道不是一个根本性的改变吗?

    1.jquery介绍:想必大家都用过jquery吧,这个曾经也是现在依然最流行的web前端js库,可是现在无论是国内还是国外他的使用率正在渐渐被其他的js库所代替,随着浏览器厂商对HTML5规范统一遵循以及ECMA6在浏览器端的实现,jquery的使用率将会越来越低

    2.vue介绍:vue是一个兴起的前端js库,是一个精简的MVVM。从技术角度讲,Vue.js 专注于 MVVM 模型的 ViewModel 层。它通过双向数据绑定把 View 层和 Model 层连接了起来,通过对数据的操作就可以完成对页面视图的渲染。当然还有很多其他的mvmm框架如Angular,React都是大同小异,本质上都是基于MVVM的理念。 然而vue以他独特的优势简单,快速,组合,紧凑,强大而迅速崛起

    3.vue和jquey对比

    jQuery是使用选择器($)选取DOM对象,对其进行赋值、取值、事件绑定等操作,其实和原生的HTML的区别只在于可以更方便的选取和操作DOM对象,而数据和界面是在一起的。比如需要获取label标签的内容:$("lable").val();,它还是依赖DOM元素的值。

    Vue则是通过Vue对象将数据和View完全分离开来了。对数据进行操作不再需要引用相应的DOM对象,可以说数据和View是分离的,他们通过Vue对象这个vm实现相互的绑定。这就是传说中的MVVM。

    4.举例说明

    场景一:列表添加一个元素,下图为vue和jquery两种操作的代码,我们从中可以看出vue只需要向数据message里面push一条数据即可完成添加一个li标签的操作,而jquery则需要获取dom元素节点,并对dom进行添加一个标签的操作,如果dom结构特别复杂,或者添加的元素非常复杂,则代码会变得非常复杂且阅读性低

    vue:

    复制代码

    <!DOCTYPE html><html><head>
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" /></head><body>
        <p id="app">
            <ul>
                <!--根据数组数据自动渲染页面-->
                <li v-for="item in message">{{item}}</li>
            </ul>
            <button @click="add">添加数据</button>
        </p></body><script src="https://unpkg.com/vue/dist/vue.js"></script><script>
        new Vue({
            el: '#app',
            data: {
                message: ["第1条数据","第2条数据"],
                i:2
            },
            methods:{            //向数组添加一条数据即可            add:function(){                this.i++
                    this.message.push("第"+this.i+"条数据")
                }
            }
        })</script>

    复制代码

    jquery:

    复制代码

    <!DOCTYPE html><html><head>
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" /></head><body>
        <p id="app">
            <ul id="list">
                <li>第1条数据</li>
                <li>第2条数据</li>
            </ul>
            <button id="add">添加数据</button>
        </p></body><script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script><script>
        $(document).ready(function() {  
        var i=2;
        $('#add').click(function() { 
           i++; 
           //通过dom操作在最后一个li元素后手动添加一个标签      $("#list").children("li").last().append("<li>第"+i+"条数据</li>")
        });  
      }); 
    </script>

    复制代码


    场景二:控制按钮的显示隐藏,下图为vue和jquery两种操作的代码,我们从中可以看出vue只需要控制属性isShow的值为true和false即可,而jquery则还是需要操作dom元素控制按钮的显示和隐藏

    vue:

    复制代码

    <!DOCTYPE html><html><head>
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" /></head><body>
        <p id="app">
            <ul>
                <!--根据数组数据自动渲染页面-->
                <li v-for="item in message">{{item}}</li>
            </ul>
            <button @click="add" v-show="isShow">添加数据</button>
            <button @click="showButton">隐藏按钮</button>
        </p></body><script src="https://unpkg.com/vue/dist/vue.js"></script><script>
        new Vue({
            el: '#app',
            data: {
                message: ["第1条数据","第2条数据"],
                i:2,
                isShow:true
            },
            methods:{            //向数组添加一条数据即可            add:function(){                this.i++
                    this.message.push("第"+this.i+"条数据")
                },            //控制isShow的值即可            showButton:function(){                this.isShow=false;
                }
            }
        })</script>

    复制代码

    jquery:

    复制代码

    <!DOCTYPE html><html><head>
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" /></head><body>
        <p id="app">
            <ul id="list">
                <li>第1条数据</li>
                <li>第2条数据</li>
            </ul>
            <button id="add">添加数据</button>
            <button id="showButton">隐藏按钮</button>
        </p></body><script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script><script>
        $(document).ready(function() {  
        var i=2;
        $('#add').click(function() { 
           i++; 
           //通过dom操作在最后一个li元素后手动添加一个标签      $("#list").children("li").last().append("<li>第"+i+"条数据</li>")
        });  
        //需要手动隐藏dom元素    $("#showButton").click(function(){
            $("#add").hide()
        })
      }); 
    </script>

    复制代码

    输出结果:

    4.总结:内容讲的比较浅,主要就是分析一下vue和jquey对比的区别,上面两个例子只是做了一个简单的说明,然而vue能解决的问题远比这些要多的多,复杂的多。

       vue适用的场景:复杂数据操作的后台页面,表单填写页面

       jquery适用的场景:比如说一些html5的动画页面,一些需要js来操作页面样式的页面

        然而二者也是可以结合起来一起使用的,vue侧重数据绑定,jquery侧重样式操作,动画效果等,则会更加高效率的完成业务需求

    5. 附上公司前端目录结构,感兴趣的可以分享代码给大家看看

    src代码目录包含assets静态文件,components vue组件文件,plugins 插件文件(包含登录操作,http请求操作,过滤器,加解密操作,公共方法等),router 路由文件,store vuex文件,app.js vue相关配置,index.html主页面

    build目录为webpack打包文件,dist目录为打包后生成的文件,node_modules 引用的外部组件


    补充阅读:

    1.jQuery首先要获取到dom对象,然后对dom对象进行进行值的修改等操作
    2.Vue是首先把值和js对象进行绑定,然后修改js对象的值,Vue框架就会自动把dom的值就行更新。
    3.可以简单的理解为Vue帮我们做了dom操作,我们以后用Vue就需要修改对象的值和做好元素和对
    象的绑定,Vue这个框架就会自动帮我们做好dom的相关操作
    4.这种dom元素跟随JS对象值的变化而变化叫做单向数据绑定,如果JS对象的值也跟随着dom元素的
    值的变化而变化就叫做双向数据绑定
    用一个简单的例子来说明编写Jquery和Vue上的不同
    修改文字
    点击按钮后:

    改为


    (1)jQuery代码

    1. <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>
      </head>
      <body>
      <p>
          <p>大家好,我是<span id="name">张三<span>!</p>
          <p>我是一名<span id="jop">医生</span>.</p>
          <button id = "modifyBtn">修改</button>
      </p>
      <script type="text/javascript">
          $("#modifyBtn").click(function(){  
              $("#name").text("李四");  
              $("#jop").text("老师");  
          });  
      </script>
      </body>
      </html>

    (2)Vue代码

    1. <!DOCTYPE html>
      <html>
      <head>
      <meta charset="utf-8">
      <title>Vue</title>
      <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
      </head>
      <body>
      <p id="app">
          <p>大家好,我是<span>{{name}}<span>!</p>
          <p>我是一名<span>{{jop}}</span>.</p>
          <button v-on:click="modifyInfo">修改</button>
      </p>
      <script>
      new Vue({  
          el: '#app',  
          data:{  
              name:"张三",  
              jop:"医生"  
          },  
          methods:{  
              modifyInfo:function(){  
                  this.name = "李四";  
                  this.jop = "老师";  
              }  
          }  
      })  
      </script>
      </body>
      </html>

    相关推荐:

    vue与jquery实时监听用户输入状态代码分享

    jQuery表单元素选择器实例讲解

    jQuery基础语法使用方法

    以上就是jquery和vue对比实例分析的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:jquery 实例分析 对比
    上一篇:AJAX之POST数据中文乱码如何解决 下一篇:node.js通过axios如何实现网络请求
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 一文了解Node.js中的包管理工具--npm• 示例解析Json对象Json字符串的序列化与反序列化• Module模块化编程的优点(总结分享)• 实例讲解node中http模块和url模块的使用方法• 什么是CommonJS?Nodejs中如何自定义模块?
    1/1

    PHP中文网