当前位置: 首页 > article >正文

Vue 学习

vue 核心语法

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vue 核心语法测试</title>
</head>

<body>
    <div id="app">
        <h1>{{title}}</h1>
        <p>{{content}}</p>
        <p>{{output()}}</p>
        <p>{{output()}}</p>
        <p>{{outputContent}}</p>
        <p>{{outputContent}}</p>
        <!-- 指令表达式 -->
        <!-- 渲染指令 -->
        <p v-text="htmlContent"></p>
        <p v-html="htmlContent"></p>
        <p v-show=bool>v-show test</p>
        <!-- v-if -->
        <!-- v-for -->
        <!-- 属性指令 -->
        <p v-bind:title="title">属性指令v-bind测试</p>
        <p :title="title">属性指令测试简写</p>
        <!-- 事件指令 -->
        <button v-on:click="output">事件指令v-on测试</button>
        <button @click="output">事件指令简写测试</button>
        <!-- 表单指令v-model: 实现数据双向绑定 -->
        <!-- 使用 v-model 杜绝了 DOM-XSS -->
        <input type="text" v-model=inputV>
        <p v-text="inputV"></p>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script>
        const vm = new Vue({
            el: "#app",
            data() {
                return {
                    title: "标题'\"><u>sabercoco</u>",
                    content: "内容",
                    // htmlContent: "This is a <script>alert(1);" => 不弹窗
                    // htmlContent: "This is a <img src=1 οnerrοr=alert(1)>" => 弹窗
                    htmlContent: "This is a <img src=1 οnerrοr=alert(/xss/)>",
                    bool: true,
                    inputV: "默认内容"
                }
            },
            // methods 属性
            methods: {
                output() {
                    console.log("output() 执行了")
                    return "标题:" + this.title + " --- " + "内容:" + this.content
                }
            },
            // computed 属性:具有缓存性
            computed: {
                outputContent() {
                    console.log("outputContent 执行了")
                    return "标题:" + this.title + " --- " + "内容:" + this.content
                }
            },
            // 侦听器
            watch: {
                // 监听 title
                title(newV, oldV) {
                    console.log("newV: " + newV + " --- " + "oldV: " + oldV)
                }
            }
        })
    </script>
</body>
</html>

使用 vue 创建一个项目

检查是否已经安装了 npm 和 node

npm --version
node --version

使用 npm 安装 vue

npm install -g @vue/cli

检查 vue 工具是否安装成功

vue --version

使用 vue 工具创建一个名为 vue-demo-project 的项目

  • 这是命令行的创建方式
    vue create vue-demo-project
  • 这是 ui 的创建方式
    vue ui

通过 vue 脚手架创建的项目结构分析

创建项目

vue create vue-demo-project
在这里插入图片描述
选择 [Vue 2],然后回车,等待项目创建完毕。

项目结构图

在这里插入图片描述

src目录和dist目录

src目录是开发者编写代码的地方,代码编写完毕后进入项目根目录执行npm run build进行代码打包,将会得到一个dist目录,这个目录就是项目上线所使用的目录,dist目录如下,
在这里插入图片描述

public目录

在这里插入图片描述
public目录中的内容不参与编译。

模拟将dist上线

进入项目根目录执行npm install serve -g安装 serve 工具,安装完毕后执行serve dist,如下,
在这里插入图片描述
访问http://localhost:3000,如下,
在这里插入图片描述
如果直接使用源码进行上线呢?来到项目根目录执行npm run serve,如下,
在这里插入图片描述
访问http://localhost:8081/,如下,
在这里插入图片描述


http://www.kler.cn/a/325233.html

相关文章:

  • 3D 视觉语言推理中的态势感知
  • vue编写一个可拖动的模块,并可以和任何其他组件组合使用
  • 【机器学习实战入门】使用OpenCV和Keras的驾驶员疲劳检测系统
  • WPF实现动态四宫格布局
  • [Collection与数据结构] PriorityQueue与堆
  • C++实现设计模式---外观模式 (Facade)
  • unity安装报错问题记录
  • Web端云剪辑解决方案,提供多轨视频、音频、特效、字幕轨道可视化编辑
  • DC00016基于java swing+MySQL房屋租赁管理系统GUI租赁管理系统javaswing项目
  • 20240926 关于Goland处理wsl-GOROOT原理猜测
  • Spring Cloud 工程搭建服务注册_服务发现
  • OCR Fusion: EasyOCR/Tesseract/PaddleOCR/TrOCR/GOT
  • 我在 Thoughtworks 被裁前后的经历
  • spark 大表与大表join时的Shuffle机制和过程
  • Python通过Sqlalchemy框架实现增删改查
  • Qt网络编程——QTcpServer和QTcpSocket
  • centos7 semanage 离线安装 SELinux
  • Vue3 + TS 实现同一项目同一链接,pc端打开是web应用,手机打开是H5应用
  • Solidity语言:重点学习Solidity编程语言,这是EVM上最常用的智能合约语言。
  • 关于大模型的10个思考
  • 828华为云征文 | 云服务器Flexus X实例:向量数据库 pgvector 部署,实现向量检索
  • Stable Diffusion零基础学习
  • 基于SpringBoot+Vue+MySQL的体育商城系统
  • Linux,C高级——day4
  • 【AI写作】解释 RESTful API,以及如何使用它构建 web 应用程序。
  • 基于nodejs+vue的水产品销售管理系统