首页 > 其他分享 >VUE3学习基础之模板语法

VUE3学习基础之模板语法

时间:2023-12-20 17:12:27浏览次数:36  
标签:npm vue const true 语法 VUE3 msg ref 模板

我的vue3学习之路总是学学停停,最开始在18年开发微信小程序,就发现小程序和vue的语法有些相似,然后就去看了vue2的文档,随后忙其它的事情就丢下了。

直到22年又开始捡起来vue3,有了组合式api,语法简明很多,然后又不知道忙什么丢下。。。

前段有些空时间,就把vue3的学习整理下,使用vite构建结合element-plus做成了一个简单的网页应用,这里记录下。毕竟学为用

使用的命令:

# 搭建 vite 项目

npm init vite@latest

# 安装依赖

npm install

# 运行

npm run dev

# 安装其它组件

npm install vue-router@4

npm install pinia

npm install ant-design-vue@4.x --save
npm install -D unplugin-vue-components unplugin-auto-import

npm install element-plus --save

# 卸载不使用的安装包

npm uninstall ant-design-vue
npm rm ant-design-vue

 目录如下

 

<script setup>
import { ref, reactive, onMounted } from "vue";

//模板语法
const msg = "hello";
const rawHtml = "<span style='color:red'>HELLO</span>";
let url = "https://www.baidu.com/";
let isButtonDisabled = true;
const objectOfAttrs = {
  href: url,
  id: "wrapper",
};
const attributeName = "href";
const eventName = "click";

const seen = true;
const type = "C";

const arr_items = ref([{ message: "Foo" }, { message: "Bar" }]);
const obj_items = reactive({
  title: "How to do lists in Vue",
  author: "Jane Doe",
  publishedAt: "2016-04-10",
});

const count = ref(0);

const isActive = ref(true);
const hasError = ref(false);
const classObject = reactive({
  active: true,
  "text-danger": true,
});
const activeClass = ref("active");
const errorClass = ref("text-danger");

const color = ref("red");
const fontSize = ref(20);
const styleObject = reactive({
  color: "red",
  fontSize: "13px",
});

function noRedirect(e) {
  console.log("clicked baidu");
  e.preventDefault();
}

function getMsg(msg) {
  return "msg:" + msg;
}

function say(message, event) {
  if (event) {
    event.preventDefault();
  }
  alert(message);
}

// 模板引用
const pEle = ref(null);
onMounted(() => {
  pEle.value.textContent = "hello,world!";
});
</script>
<template>
  <div>
    <el-row :gutter="5">
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>文本插值</span>
            </div>
          </template>
          <div>
            <p>MSG:{{ msg }}</p>
            <p>倒置的MSG:{{ msg.split("").reverse().join("") }}</p>
            <p>表达式:{{ "msg:" + msg }}</p>
            <p>调用函数:{{ getMsg(msg) }}</p>
          </div>
        </el-card>
      </el-col>
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>原始 HTML </span>
            </div>
          </template>
          <div>
            <p>原始 HTML:{{ rawHtml }}</p>
            <p>原始 HTML: <span v-html="rawHtml"></span></p>
          </div>
        </el-card>
      </el-col>
    </el-row>

    <el-row :gutter="5">
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>Attribute 绑定</span>
            </div>
          </template>
          <div>
            <el-link type="primary" v-bind:href="url" target="_blank">Attribute 绑定</el-link>
            <el-link type="primary" :href="url" target="_blank">Attribute 绑定</el-link>

            <el-button type="primary" :disabled="isButtonDisabled">
              布尔型 Attribute 依据 true/false 值来决定 attribute 是否应该存在于该元素上。
            </el-button>

            <el-link type="primary" v-bind="objectOfAttrs" target="_blank">动态绑定多个值</el-link>
            <p>
              <el-link type="primary" v-bind:[attributeName]="url" v-on:[eventName]="noRedirect" target="_blank"
                >动态参数</el-link
              >
              <el-link type="primary" :[attributeName]="url" @[eventName]="noRedirect" target="_blank"
                >动态参数</el-link
              >
            </p>
          </div>
        </el-card>
      </el-col>
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>事件监听</span>
            </div>
          </template>
          <div>
            <p>Count is: {{ count }}</p>
            <el-button type="primary" @click="count++"> Add 1 </el-button>

            <el-button type="primary" @click="say('hello')"> Say hello </el-button>
            <el-button type="primary" @click="say('bye')"> Say bye </el-button>
            <el-button type="primary" @click="say('bye', $event)"> Say bye </el-button>

            <el-link type="primary" v-bind:href="url" v-on:click="noRedirect" target="_blank">不跳转链接</el-link>
            <el-link type="primary" :href="url" @click="noRedirect" target="_blank">不跳转链接</el-link>
          </div>
        </el-card>
      </el-col>
    </el-row>

    <el-row :gutter="5">
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>条件渲染</span>
            </div>
          </template>
          <div>
            <p>
              <span v-if="seen">Now you see me</span>
              <span v-else>Oh no</span>
            </p>
            <p>
              <span v-if="type === 'A'">A</span>
              <span v-else-if="type === 'B'">B</span>
              <span v-else-if="type === 'C'">C</span>
              <span v-else>Not A/B/C</span>
            </p>
            <p v-show="seen">
              v-show 元素始终会被渲染,只有 CSS display 属性会被切换。<br />
              v-if 也是惰性的:只有当条件首次变为 true 时才被渲染。
            </p>
          </div>
        </el-card>
      </el-col>
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>列表渲染 </span>
            </div>
          </template>
          <div>
            <p>
              <span v-for="(item, index) in arr_items" :key="`item-${index}`">{{ index }} - {{ item.message }}</span>
            </p>
            <p>
              <span v-for="(value, key, index) in obj_items" :key="`obj-${index}`">
                {{ index }}. {{ key }}: {{ value }}
              </span>
            </p>
            <p>
              <span v-for="n in 10" :key="`num-${n}`">{{ n }}</span>
            </p>
          </div>
        </el-card>
      </el-col>
    </el-row>

    <el-row :gutter="5">
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>Class 绑定</span>
            </div>
          </template>
          <div>
            <span :class="{ active: isActive }">类是否存在取决于数据的真假值</span>
            <span class="static" :class="{ active: isActive, 'text-danger': hasError }">class</span>
            <span :class="classObject">class</span>
            <span :class="[activeClass, errorClass]">class</span>
            <span :class="[{ active: isActive }, errorClass]">class</span>
          </div>
        </el-card>
      </el-col>
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>Style 绑定 </span>
            </div>
          </template>
          <div>
            <span :style="{ color: color, fontSize: fontSize + 'px' }">Style</span>
            <span :style="styleObject">Style</span>
          </div>
        </el-card>
      </el-col>
    </el-row>

    <el-row :gutter="5">
      <el-col :span="12">
        <el-card class="box-card">
          <template #header>
            <div class="card-header">
              <span>模板引用</span>
            </div>
          </template>
          <div>
            <p ref="pEle">hello</p>
          </div>
        </el-card>
      </el-col>
    </el-row>
  </div>
</template>
<style scoped>
.active {
  color: blue;
}
.text-danger {
  border: 1px solid red;
}

.el-row {
  margin-top: 0.5rem;
}
a,
button {
  margin-left: 1rem;
}
</style>

 

标签:npm,vue,const,true,语法,VUE3,msg,ref,模板
From: https://www.cnblogs.com/caroline2016/p/17917000.html

相关文章

  • vue3学习笔记(四)
    表单输入绑定<!--文本(Text)--><inputv-model="message"placeholder="editme"/><p>Messageis:{{message}}</p><!--多行文本(Textarea)--><textareav-model="message"placeholder="addmultipl......
  • Python中配置Excel导出模板
    定义Excel列对象classExcelColumn:"""定义Excel中的列参数:name(str):列的名称。width(int|None,可选):列的宽度。默认为None。required(bool,可选):指示列是否必需。默认为False。mapping_factory(Callable......
  • uniapp vue3版本的scroll-view的scroll-into-view方法不生效解决
    问题代码如图bug原因建了vue2版本和vue3版本的uniapp分别测试,vue3版本的scroll-view存在scroll-into-view不生效的问题,目前未修复(23.12.20)解决方法,换了个思路,如图思路:获取当前选中元素的left值,并动态绑定给scroll-left实现定位效果......
  • vue3 实现用户登录和权限验证思路梳理
    2023-12-20星期三一、用登录和退出问题1登录 思路一: 1.1login登录页面,将token存储本地中。 1.2前置路由守卫获取token并验证, 1.3前置路由从缓存中获取用户的访问权限,并生成动态路由。 1.4aixos请求拦截器,从存储中获取存储的token,在所有请求前,设置请求头 思......
  • 设计模式—模板模式
    介绍代码游戏模板类定义一个游戏模板虚类Game,抽象并规范好游戏的进行流程publicabstractclassGame{abstractvoidinit();abstractvoidstartPlay();abstractvoidendPlay();//模板publicfinalvoidplay(){//初始化......
  • vue中@param 常用注释模板
    /***获取事件在列表中的位置*@paramcontext*@paramcallback*@private*/_evIndex(event,context,callback){letindex=-1;for(leti=0;i<=event.length;i++){if(event[i].context===contex&&event[i].callback===callback){......
  • vue3全栈项目:具有登录注册验证的在线实时聊天应用程序。
     项目主要实现的功能:登录注册的身份验证功能(利用JWT)来实现,在与后端验证的时候,会根据不同的身份显示不同的界面;而且根据不同角色赋予不同的权力,如管理员能查看信息,而普通用户只能登录到公共组件——在线实时俩天应用程序。多人在线实时聊天功能——前后端之间根据WebSocket......
  • vue3如何实现断点续传
    首先创建一个vue3项目普通上传//template<inputtype="file"ref="uploadRef"@change="upload"/>//jssetupfunctionupload(event){letfiles=event.target.filesletformData=newFormData()formData.append("file",file......
  • Postgresql中PL/pgSQL代码块的语法与使用-声明与赋值、IF语句、CASE语句、循环语句
    场景PostGresSQL简介与Windows上的安装教程:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/113981563除了标准SQL语句之外,PostgreSQL还支持使用各种过程语言(例如PL/pgSQL、C、PL/Tcl、PL/Python、PL/Perl、PL/Java等)创建复杂的过程和函数,称为存储过程(Store......
  • 脚手架搭建vue3项目
    vue官网:https://cn.vuejs.org/ 下面将搭建一个最基本的vue3项目,包含vue3、ts、pinia、element-plus、scss、api-proxy等配置。步骤如下:1.按脚手架初始化项目进入vue官网的快速上手,按照官网所述,执行:npmcreatevue@latest,然后,按照提示选择 typescript/vue-router/pin......