三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)

这篇具有很好参考价值的文章主要介绍了三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

最近找导师重新更换了研究方向,学的东西还是蛮杂的,本来就是一个代码菜鸟,捣鼓一大堆,全栈开发、各种语言、区块链开发等等,之前总是想要学会一项,完成一样功能才记录。目前我要完成的项目是一个智慧海洋牧场平台,前期学习了Flask+mysql+echarts的可视化展示,现在需要学习cesium和vue搭建三维交互平台,之前用的都是原生js,甚至连jquery也没有学,唯一用的就是ajax,给各位看看我想完成的目标(注意是我想完成的,因为我觉得目前在水产养殖行业缺少这种,而导师不这么想,下面会说到),如图:
三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)
以下是和导师交流过多次的需求图,有点乱,不过大致能理解就是一个管理系统,他说实时数据和监控的接口都会给我,如图:
三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)

学习路线是先vue,再前后端分离,接着做项目的管理系统,把管理系统完善后,最后学习cesium三维交互,达到我想要研究的最终效果。

环境

pycharm 2019 专业版
Flask框架
三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)

Vue入门

我是跟着这篇文章一路敲下来的,感兴趣的朋友请看这篇,接下来我的思路问题也会按照这篇进行。
原文链接:Vue

  • Vue安装

    按照这篇文章
    vue安装测试
    先把vue该有的环境搭建好,该下载的下载,测试成功就行。

  • 案例分析

    敲第一个案例发现 v-model 黄色,提示"Attribute v-xxx is not allowed here",我是引入了Vue.js的,经过资料查找需要在编译器插件中下载Vue.js,这样就会有代码提示,并且不会报错。
    三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)
    1.vue基础
    大致了解vue怎么工作,基本语法v-bind,v-model,v-if,v-for,v-on等等,注意data中的数据都是json格式的,v-on需要注意涉及到方法调用,需要写一个类似于js的方法,下面以v-on为例模板:

    <div id="app"> 
    <!--click绑定了sayHi方法-->
        <button v-on:click="sayHi">点我</button>
    </div>
    
    <!--1.导入Vue.js-->
    <script src="../../static/js/vue.js"></script>
    <script type="text/javascript">
        var vm = new Vue({
            el:"#app",
            data:{
                message:'Hello World'
            },
            methods:{
                sayHi:function(event){
                    //'this'在方法里面指向当前Vue实例
                    alert(this.message);
                }
            }
        });
    </script>
    

    2.v-model双向数据绑定
    以多行文本为例:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <div id="app">
       多行文本:<textarea v-model="pan"></textarea>&nbsp;&nbsp;多行文本是:{{pan}}
    </div>
    
    <script src="../js/vue.js"></script>
    <script type="text/javascript">
        var vm = new Vue({
            el:"#app",
            data:{
            //注意这里是pan,要与上面的{{pan}}一致,原文里写的是message
                pan:"Hello hello!"
            }
        });
    </script>
    </body>
    </html>
    
    

    3.组件部分
    一组可以重复使用的模板,一个框架里有多个组件,可复用。
    分为全局组件和局部组件:全局组件在Vue实例外部定义。局部实例在实例内定义,且仅在父模板内可用。
    自定义指令,Vue.directive()全局指令。Vue实例中的directives属性,添加的是局部属性。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>组件:可复用型</title>
        <script src="../../static/js/vue.js"></script>
    </head>
    <body>
        <div id="app">
            <pan v-for="item in items" v-bind:panh="item"></pan>
        </div>
        <!--Vue.cpomponent()注册组件 pan 定义组件名字 -->
        <script type="text/javascript">
            // 先注册组件
            Vue.component("pan",{
            //pros是属性
                props:['panh'],
                template: '<li>{{ panh }}</li>'
            });
            // 再实例化Vue
            var vm = new Vue({
                el:"#app",
                data:{
                // 参数放在data中被调用
                    items:['a','b','c']
                }
            });
        </script>
    </body>
    </html>
    
    

    4.异步axios
    使用axios有几个方法,这里选两个:
    1).在终端输入:npm install axios
    使用时
    import Axios from 'axios' Vue.prototype.$axios=Axios
    (这种方法我试了不好使,网页提示Cannot use import statement outside a module)
    2).在编译器直接引入并使用:
    html <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
    这种可以

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            {#解决闪烁问题#}
            [v-cloak]{
                display: none;
            }
        </style>
        <script src="../../static/js/vue.js"></script>
        <!--Axios异步通信,vue的ajax需要用到vue-resource库的axios-->
    </head>
    <body>
    <div id="vue">
        <div>地名:{{ info.name }}</div>
        <div>地址:{{ info.address.country }}--{{ info.address.city }}--{{ info.address.street }}</div>
        <div>链接:<a v-bind:href="info.url" target="_blank">{{ info.url }}</a></div>
    </div>
    
    <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
    <script type="text/javascript">
    
        var vm = new Vue({
            el:"#vue",
            // data属性vm
            data(){
                return{
                    info:{
                        name:null,
                        address:{
                            country:null,
                            city:null,
                            street:null
                        },
                        url:null
                    }
                }
            },
            mounted() {
                //钩子函数,get中的url是json本目录下的json文件
                axios.get('data.json')
                    .then(response=>(this.info=response.data));
                //这个等价于什么呢
            }
        });
    
    </script>
    
    </body>
    </html>
    

    5.计算属性
    跑5.2的时候达不到预期,应该是原文代码有问题,我就放弃按照原文敲了,转到
    三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)

    computed和methods的效果相同,但是他们的区别在于computed性能更好,如果不用缓存,可以使用methods。
    computed默认属性有getter,也可以设定setter

    <div id="app">
      <p>{{ site }}</p>
    </div>
    <script>
        var vm = new Vue({
            el:'#app',
            data:{
                name:'zhang',
                url:'www.baidu.com'
            },
            computed:{
                site:{
                    get:function () {
                        return this.name + '  ' +this.url
                    },
                    set:function (newValue) {
                        var names = newValue.split(' ')
                        this.name = names[0]
                        this.url = names[names.length - 1]
                    }
                }
            }
        })
        vm.site = '菜鸟教程http://www.ds';
    </script>
    

    6.监听属性
    类似于v-on自动触发版,@click是v-on:click的简写

    <div id="app">
        <!--
        <h1>计数器:{{ counter }}</h1>
        <button @click="counter++">点击</button>
        -->
        千米:<input type="text" v-model="kilometers">
        米:<input type="text" v-model="meters">
    </div>
    <script>
    var vm = new Vue({
        el: '#app',
        data: {
            kilometers: 0,
            meters: 0
        },
        watch:{
            kilometers:function (val) {
                this.kilometers = val;
                this.meters = this.kilometers*1000;
            },
            meters:function (val) {
                this.meters = val;
                this.kilometers = this.meters/1000;
            }
        }
    });
    // vm.$watch('counter', function(nval, oval) {
    //alert('计数器值的变化 :' + oval + ' 变为 ' + nval + '!');
    //});
    </script>
    

    7.样式绑定
    后面的样式属性会覆盖前面相同的属性,例如background

    <style>
    .active {
    	width: 100px;
    	height: 100px;
    	background: green;
    }
    .text-danger {
    	background: red;
    }
    </style>
    </head>
    <body>
    
    <div id="app">
        <div v-bind:class="[activeClass, errorClass]"></div>
    </div>
    
    <script>
    new Vue({
      el: '#app',
      data: {
        activeClass: 'active',
          errorClass: 'text-danger'
      }
    })
    </script>
    

    8.事件处理器
    以下是事件修饰符,还有按键修饰符,第6节已经介绍@click,其他也是类似写法

    <!-- 阻止单击事件冒泡 -->
    <a v-on:click.stop="doThis"></a>
    <!-- 提交事件不再重载页面 -->
    <form v-on:submit.prevent="onSubmit"></form>
    <!-- 修饰符可以串联  -->
    <a v-on:click.stop.prevent="doThat"></a>
    <!-- 只有修饰符 -->
    <form v-on:submit.prevent></form>
    <!-- 添加事件侦听器时使用事件捕获模式 -->
    <div v-on:click.capture="doThis">...</div>
    <!-- 只当事件在该元素本身(而不是子元素)触发时触发回调 -->
    <div v-on:click.self="doThat">...</div>
    
    <!-- click 事件只能点击一次,2.1.4版本新增 -->
    <a v-on:click.once="doThis"></a>
    

    9.Vue路由
    vue路由需要加载vue-router库:
    npm install vue-router@4
    使用时,引用的@3.0.0始终指向最新版本,所以不用担心

    <script https://unpkg.com/vue-router@3.0.0/dist/vue-router.js"></script>
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="../../static/js/vue.js"></script>
        <script src="https://unpkg.com/vue-router@3.0.0/dist/vue-router.js"></script>
    </head>
    <body>
         <div id="app">
             <h1>hello,router</h1>
             <!--<router-link> 是一个组件,默认被渲染成一个<a>标签,
             该组件用于设置一个导航链接,切换不同 HTML 内容。
             to 属性为目标地址, 即要显示的内容。
             以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。-->
             <p>
                 <router-link to="/foo">Go to foo</router-link>
                 <router-link to="/bar">Go to bar</router-link>
             </p>
             <!--路由出口,匹配到的组件渲染在这-->
             <router-view></router-view>
             </div>
             <script type="text/javascript">
                 //1.定义路由组件,也可以从其他文件导入
                 const Foo = {template:'<div>foo</div>'}
                 const Bar = {template:'<div>bar</div>'}
                 //2.定义路由
                 //每个路由应该映射一个组件,其中可以是"component"
                 //通过Vue.extend()创建的组件构造器
                 const  routes = [
                     {path:'/foo',component:Foo},
                     {path:'/bar',component:Bar}
                 ]
                 //3.创建router实例,传'routes'配置
                 const router = new VueRouter({
                     routes //相当于routes:routes
                 })
                 //4.创建和挂载根实例
                 //要通过router配置参数注入路由,从而让整个应用都有路由功能
                 const app = new Vue({
                     router
                 }).$mount('#app')
             </script>
    
    </body>
    </html>
    

    10.实例运用
    1)案例一:导航栏,根据点击不同的链接,下面会产生相应文字
    用法总结:抛开css样式不谈,在点击链接时触发makeActive方法,将item参数赋给active触发{{active}},延伸可以用作方法绑定或者页面跳转,点击导航栏,跳转到某个url。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>实例训练一,导航栏</title>
        <script src="../../static/js/vue.js"></script>
    <!--    <link rel="stylesheet"  href="../../static/less/new_1.css">-->
    </head>
    <body>
    <div id="app">
    <!--    激活的菜单样式为active类-->
    <!--    为了阻止链接点击时跳转,使用了“prevent”修饰符-->
        <nav v-bind:class="active" @click.prevent>
            <!--当菜单上的链接被点击时,调用了makeActive方法,在Vue实例中创建-->
            <a href="#" class="home" @click="makeActive('home')">Home</a>
            <a href="#" class="projects" @click="makeActive('projects')">Projects</a>
            <a href="#" class="services" @click="makeActive('services')">Services</a>
            <a href="#" class="contact" @click="makeActive('contact')">Contact</a>
        </nav>
        <p>选择了<b>{{active}}</b></p>
        </div>
        <script>
            var vm = new Vue({
                el:'#app',
                data:{
                    active:'home'
                },
                //点击菜单使用的函数
                methods:{
                    makeActive: function (item) {
                        this.active = item;
                    }
                }
            })
        </script>
    
    </body>
    </html>
    

    2)案例二:文本编辑
    用法总结:抛开css样式不谈,@click绑定显示编辑栏和隐藏编辑栏方法,利用v-model与文本双向绑定。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>文本编辑</title>
        <script src="../../static/js/vue.js"></script>
    </head>
    <body>
    <div id="app" @click='hideTooltip'>
        <div @click.stop v-if="show_tooltip">
            <input type="text" v-model="text_content">
        </div>
        <p @click.stop="toggleTooltip">{{text_content}}</p>
    </div>
    <script type="text/javascript">
        var vm = new Vue({
            el:'#app',
            data:{
                show_tooltip:false,
                text_content:'点我编辑'
            },
            methods:{
                hideTooltip:function () {
                    this.show_tooltip = false;
                },
                toggleTooltip:function () {
                    this.show_tooltip = !this.show_tooltip;
                }
    
            }
        })
    </script>
    </body>
    </html>
    

附注:

我编译器里的less代码里面的选择器嵌套无法识别,例如

.from_box{
	form{
	input{}
	}
}
//以上识别不了


.from_box form input{}
//这种可以

以下两篇文章教你如何在编译器中使用less
12文章来源地址https://www.toymoban.com/news/detail-405438.html

//这里后缀注意是.css
less只是预编译
.css才是你要调用的
<link rel="stylesheet"  href="../static/less/index.css">

到了这里,关于三维交互可视化平台(智慧海上牧场平台)学习开发之Vue(一)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数字孪生智慧工厂三维可视化系统解决方案,打造新一代智慧工厂

    在制造业的快速发展和数字化转型的时代,智慧工厂已经成为制造企业前进的必经之路。数字孪生技术,作为工业数字化转型的核心动力,为打造智慧工厂提供了关键支持。其中,数字孪生智慧工厂三维可视化系统解决方案无疑是制造企业的得力助手,通过实时数据采集、数

    2024年02月08日
    浏览(72)
  • 数字孪生智慧校园三维可视化管理系统解决方案

    随着科学技术的进步,人们对于生活的要求也越来越高。而教育也不例外。要想让学生受益于科学的进步,那么教育就必须要跟上时代的步伐。这就是“智慧校园”诞生的原因。 教育部等六部门于2021年7月印发的《关于推进教育新型基础设施建设构建高质量教育支撑体系的指

    2024年02月16日
    浏览(64)
  • 三维可视化智慧工地源码,数字孪生可视化大屏,微服务架构+Java+Spring Cloud +UniApp +MySql

    源码技术说明 微服务架构+Java+Spring Cloud +UniApp +MySql;支持多端展示(PC端、手机端、平板端);数字孪生可视化大屏,一张图掌握项目整体情况;使用轻量化模型,部署三维可视化管理,与一线生产过程相融合,集成数据后台,统一前端入口,呈现多方项目信息;用户PC端、移动

    2024年02月03日
    浏览(94)
  • 三维可视化平台有哪些?Sovit3D可视化平台怎么样?

    随着社会经济的发展和数字技术的进步,互联网行业发展迅速。为了适应新时代社会发展的需要,大数据在这个社会经济发展过程中随着技术的进步而显得尤为重要。同时,大数据技术的快速发展进程也推动了可视化技术的飞速发展,国内外各类可视化工具软件平台如雨后春

    2024年02月13日
    浏览(52)
  • 数字乡村三维可视化监控管理平台

    数字乡村是伴随网络化、信息化和数字化在农业农村经济社会发展中的应用,既是乡村振兴的战略方向,也是建设数字中国的重要内容。为了进一步提升乡村治理智能化、专业化水平,解决建设顶层缺失、数据孤岛等问题,数字孪生技术被广泛应用于数字乡村建设中。 听涛观

    2024年02月12日
    浏览(39)
  • 剧院建筑三维可视化综合管控平台提高安全管理效率

    随着数字孪生技术的高速发展,智慧楼宇也被提上日程,以往楼宇管理存在着设备故障排查困难、能源浪费与管理不足、安全性和风险高等问题,而智慧楼宇数字孪生可视化中控平台,打造智慧楼宇管理一张图,实现了智慧建筑和楼宇的智能化、自动化和数字化管理。 智慧楼

    2024年02月07日
    浏览(53)
  • 数字孪生特高压电网三维可视化平台实现能源智能管理

    电力是现代社会不可或缺的基础能源,而有效管理电力资源对于实现可持续发展至关重要。近年来,随着物联网、大数据、人工智能等技术的快速发展,电网领域的数字化转型已经成为一种趋势。而其中关键的一环便是电网三维数字孪生技术,它为实现智能能源管理的未来打

    2024年02月06日
    浏览(66)
  • 智慧电网数据可视化运维云平台解决方案

    智慧电力概述 智慧电力是通过采用先进的大数据、云计算、物联网、边缘计算等技术,实现生产信息与管理信息的智慧,实现人、技术、经营目标和管理方法的集成,是企业管理思想的一个新突破。智慧电厂建设具备智能化、一体化、可观测、可互动、自学习、自寻优等九大

    2024年01月20日
    浏览(62)
  • 化工园区数字孪生可视化管控平台,赋予园区安全环保智慧发展

    化工行业作为国民经济的支柱和工业发展的引擎,对安全生产、环保节能、应急管控有着很高的要求。目前国内外化工园区面临安全和环保两大压力。为有效解决这两大难题,巨蟹数科综合运用物联网、数字孪生等新一代信息技术,建设了数字孪生园区智慧化管理平台,对安

    2024年02月06日
    浏览(67)
  • 智慧消防:如何基于视频与智能分析技术搭建可视化风险预警平台?

    消防安全是一个重要的话题,涉及到每个人的生活和安全。每年都会发生大量的火灾,给人们带来极大的危害,摧毁了大量的财产,甚至造成了可怕的人员伤亡。而消防安全监督管理部门人员有限,消防安全监管缺乏有效的技术手段支撑和社会化手段配合,无法及时发现、消

    2024年02月15日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包