H5部分新增属性解析


HTML5 HTML的第五个版本
H5一般指的是移动端的开发

  • 新增的属性

placeholder
input中type类型
draggable
contenteditable

-新增的属性--placeholder

如下举例说明:

< input type=“text” name=“fname” placeholder=“First name”>
在这里插入图片描述

可设置颜色

		<style>
			::-webkit-input-placeholder { /* WebKit, Blink, Edge */
			    color:    #909;
			}
			:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
			   color:    #909;
			   opacity:  1;
			}
			::-moz-placeholder { /* Mozilla Firefox 19+ */
			   color:    #909;
			   opacity:  1;
			}
			:-ms-input-placeholder { /* Internet Explorer 10-11 */
			   color:    #909;
			}
			</style>

如下图:
在这里插入图片描述

新增的属性-- input中type类型

email

email 类型用于应该包含 e-mail 地址的输入域。在提交表单时,会自动验证 email 域的值。

<form action="/example/html5/demo_form.asp" method="get">
E-mail: <input type="email" name="user_email" /><br />
<input type="submit" />
</form>

如下图:
在这里插入图片描述


url

url 类型用于应该包含 URL 地址的输入域。在提交表单时,会自动验证url 域的值。

<form action="/example/html5/demo_form.asp" method="get">
Homepage: <input type="url" name="user_url" /><br />
<input type="submit" />
</form>

如下图:
在这里插入图片描述


number

number 类型用于应该包含数值的输入域。还能够设定对所接受的数字的限定

<form action="/example/html5/demo_form.asp" method="get">
Points: <input type="number" name="points" min="1" max="10" />
<input type="submit" />
</form>

在这里插入图片描述

range

range 类型用于应该包含一定范围内数字值的输入域。range 类型显示为滑动条。还能够设定对所接受的数字的限定,默认数值value,为设定最大和最小的中间值
step规定了滚轮改变数值的最小单位,

   Points:<input type="range" name="points" min="1" max="10" step="1"/>

如下图:
在这里插入图片描述


date - 选取日、月、年
month - 选取月、年
week - 选取周和年
time - 选取时间(小时和分钟)
datetime - 选取时间、日、月、年(UTC 时间)
datetime-local - 选取时间、日、月、年(本地时间)

以上列举两项:
date - 选取日、月、年

Date: <input type="date" name="user_date" />

效果如下图:
在这里插入图片描述

month - 选取月、年

Month: <input type="month" name="user_date" />

如下:
在这里插入图片描述


search
search 类型用于搜索域

<input type="search" name="username">

如下图
在这里插入图片描述
提交表单后,再次鼠标聚焦会提示历史内容
如下图:
在这里插入图片描述


color

颜色输入框

在这里插入图片描述


表单元素(兼容性较差)
拓展:

< datalist> 元素规定输入域的选项列表。
属性规定 form 或 input 域应该拥有自动完成功能。当用户在自动完成域中开始输入时,浏览器应该在该域中显示填写的选项

例子:

<form action="demo-form.php" method="get">
<input list="browsers" name="browser">
<datalist id="browsers">
  <option value="Internet Explorer">
  <option value="Firefox">
  <option value="Chrome">
  <option value="Opera">
  <option value="Safari">
</datalist>
<input type="submit">
</form>

<p><strong>注意:</strong> Internet Explorer 9(更早 IE 版本),Safari 不支持 datalist 标签。</p>

效果图如下:
在这里插入图片描述
拓展2:

< output> 元素用于不同类型的输出,比如计算或脚本输出
for属性用于计算输出

<form oninput="x.value=parseInt(a.value)+parseInt(b.value)">0
<input type="range" id="a" value="50">100
+<input type="number" id="b" value="50">
=<output name="x" for="a b"></output>
</form>
​
<p><strong>注意:</strong>  Internet Explorer 不支持 output 标签。</p>

在这里插入图片描述

拖放(Drag 和 Drop)属性draggable

说明:拖放是一种常见的特性,即抓取对象以后拖到另一个位置。
在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放。

设置元素为可拖放

 <img draggable="true">

拖拽事件
生命周期

1.鼠标按下,拖拽开始时触发 ondragstart
2.移动鼠标,拖拽中 ondrag
3.松开鼠标,拖拽结束 ondragend

拓展1:
event为触发时产生的对象,里面包含了事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态。
event.clientX; event.clientY;为鼠标在浏览器中的坐标

拓展2:

DOM 中的 offset 属性
当元素的父节点为body时,offsetParent为window(浏览器窗口),
图例:
在这里插入图片描述
例子:

<body>
<div class="div01" draggable="true"></div>	   <!--将拖拽属性设置为true,可以拖拽-->
<script>
	var divdrag = document.getElementsByClassName("div01")[0] //绑定拖拽元素
	var starx = 0;                                           //设置拖拽元素位置初始化
	var stary = 0;  
	//拖拽开始
	divdrag.ondragstart = function(event){                     //  	设置拖拽元素的最开始拖拽位置的初始坐标
		starx = event.clientX;
		stary = event.clientY;
           
	}
	//拖拽移动中
	divdrag.ondrag = function(){
		console.log("mover")
	}
	//拖拽结束
	divdrag.ondragend = function(){           //拖拽结束后的位置坐标与起始位置的坐标之间的差,就是要定位元素的地方
		var x = event.clientX - starx;
		var y =event.clientY - stary;
		
		divdrag.style.top = divdrag.offsetTop + y + "px"
		divdrag.style.left = divdrag.offsetLeft + x+ "px"
	}
	
</script>

进入目标元素也有几个对应的事件

兼容性问题,目前版本的Firefox不支持

1,当拖拽元素进入区域触发(必须是鼠标进入) ondragenter
2,当拖拽元素的鼠标进入区域,不断触发 ondragover
3,当拖拽元素的鼠标进入区域后离开,触发 ondragleave
4,当拖拽元素的鼠标进入区域后松开鼠标,触发 ondrop

</head>
<body>
	<div class="div01">
		<ul>
			<li>HTML</li>
			<li>CSS</li>
			<li>JAVASCRIPT</li>
		</ul>
	</div>
	<div class="div02"></div>
	<script>		
		var lis = document.getElementsByTagName("li");
		var domEle;
		for(var i = 0; i < lis.length;i++){
			lis[i].setAttribute("draggable","true");
			lis[i].ondragstart = function(event){
				domEle = event.target || event.srcElement;
			}
		}

		var div02 = document.getElementsByClassName("div02")[0];
		div02.ondragover = function(event){    
			event.preventDefault();
		}
		div02.ondrop = function(event){ 
			div02.appendChild(domEle)	
			domEle = null;
		}

		var div01 = document.getElementsByClassName("div01")[0];
		div01.ondragover = function(event){    
			event.preventDefault();   //阻止默认行为,可以把这个行为给阻止掉,阻止事件冒泡
		}
		div01.ondrop = function(event){ 
			div01.appendChild(domEle)	
			domEle = null;
		}
	</script>

event.preventDefault(); 阻止默认行为,可以把这个行为给阻止掉,(阻止事件冒泡)

参考博客:事件冒泡、事件捕获和事件委托

contenteditable

定义
contenteditable 属性规定元素内容是否可编辑。
可以继承的,可以覆盖

可继承:父级元素中的所有contenteditable属性与父级一致
例子:

 <div contenteditable="true">hello world</div>

如图:
在这里插入图片描述

例2:

<div contenteditable="true">
		<span contenteditable="false">用户名:</span>
		<span>张三	</span>
	</div>

如下图:
在这里插入图片描述
可覆盖:父级中可以允许自己contenteditable属性与自己不一致
contenteditable="false"时为不可编辑状态,
但可以在父级元素为可编辑状态下作为最小编辑单位被整个删除

返回底部

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: h5扫一扫是指在手机浏览器中打开的网页通过调用手机摄像头的功能,扫描条形码以获取相关信息的一种技术。 扫描条形码的过程通常由浏览器自带的扫码功能实现,扫描完成后,浏览器会自动解析条形码,将其转换成数字或字符等信息,然后通过跳转链接或展示内容方式呈现给用户。 条形码是一种将数据编码成一系列竖条和空格的图像符号,是个数字化的信息表示形式。扫描条形码可以用于识别商品、快递、机票、门票等不同的物品,将其与相应信息进行关联。在商业、物流、娱乐等领域都得到了广泛的应用。 h5扫一扫技术在移动互联网时代具有重要的作用,方便用户获取相关信息,提高用户的消费体验。同时,也方便商家和生产厂家对商品进行管理、溯源和防伪等方面的工作。随着技术的不断发展,h5扫一扫技术将越来越广泛的应用于各种场景中。 ### 回答2: H5扫一扫是一种便捷的业务实现方式。在使用时,用户只需要通过手机摄像头扫描条形码,即可实现相关业务操作。在扫描时,系统会自动对条码进行解析,并将相关信息进行提取,从而实现业务操作。条形码的解析过程包括两个步骤:图像识别和码值解析。在图像识别阶段,系统会通过算法分析条形码图像,确定条码的位置、方向和大小等信息。在码值解析阶段,系统则会对条形码的码值进行解析,并将其转化为可读的文字或数字。需要注意的是,在解析过程中,图像质量的好坏对系统的识别效果有很大的影响。因此,在进行条形码扫描操作时,用户应该注意环境的光线和防抖等情况,以提高识别的准确率。总体来说,H5扫一扫是一种方便快捷的业务操作方式,广泛应用于各种行业的业务流程中。通过对条形码的高效解析,用户可以快速地完成业务操作,提高工作效率和用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值