数据验证css,纯CSS实现数据上报和HTML验证

一、纯CSS实现数据上报

举个例子,要跟踪并统计某个按钮的点击事件:

.button-1:active::after {

content: url(./pixel.gif?action=click&id=button1);

display: none;

}

.button-2:active::after {

content: url(./pixel.gif?action=click&id=button2);

display: none;

}

此时,当我们点击按钮的时候,相关行为数据就会上报给服务器,这种上报,就算把JS禁掉也无法阻止。

当然,我们可以统计的不仅仅是单击行为,hover行为,focus行为都可以统计,当然,还有很多其他方面的。例如:

1. 不支持CSS3浏览器比例统计

.any-element {

background: url(./pixel.gif?css=2);

background-image: url(./pixel.gif?css=3), none;

}

web前端开发学习Q-q-u-n: 767273102 ,分享开发工具,零基础,进阶视频教程,希望新手少走弯路

例如,我的Chrome发出的图片请求地址就是:

939dc1c6da1f3508ee81b8fe2e61aaf1.png

类似的,我们可以检测支持其他一些CSS属性的比例,要比单纯看浏览器的占比要精准的多。因为同样是Chrome浏览器,不同用户版本可能不一样,要想准确知道某些CSS新特性支持情况,这种CSS上报方法要更准确。

可以使用@supports规则。

.any-element {

background: url(./pixel.gif?grid=0);

}

@supports (display: grid) {

.any-element {

background: url(./pixel.gif?grid=1);

}

}

2. retina屏幕占比统计

要么上报0,要么上报1,最后可以知道retina屏幕的比例。

.any-element {

background: url(./pixel.gif?retina=0);

}

@media screen and (-webkit-min-device-pixel-ratio: 2) {

.any-element {

background: url(./pixel.gif?retina=1);

}

}

例如,我家里的window普通显示屏:

925c651b7eb67f7e732482cbfcb5303a.png

类似的,可以检测宽屏设备比例等。

3. 是否支持某字体

例如,用户是否电脑是否安装了思源黑体:

@font-face {

font-family: anyFontName;

src: url(../image/pixel.gif?font=unmatch&id=s_h_s);

}

.element-with-text {

font-family: 'Source Han Sans CN', 'anyFontName';

}

这个要看font请求,如果你的浏览器没有安装思源黑体,则会尝试加载anyFontName这个字体,于是发起了请求,如下图所示:

d3a325ce950ec72b4ceb91d9d70ad813.png

如果安装,则没有上报。

//zxx: 对于一些常见中文字体在CSS中的英文名称,可以参见我之前的研究成果:“CSS font-family常见中文字体对应的英文名称”。

以上1,2,3三个CSS上报数据的小按钮,您可以狠狠地点击这里亲自体验一番:一些CSS跟踪上报示意demo

页面截图如下:

2ec95b9ce86b1f1ef86f51f41706a3e3.png

我们还可以借助浏览器原生行为简化我们上报成本,比方说表单验证出错,用来统计用户注册或者其他重要表单操作的成功率。

CSS如下:

.track:invalid {

background: url(./pixel.gif?action=regist&status=invalid);

}

.track:valid {

background: url(./pixel.gif?action=regist&status=valid);

}

每当表单提交的时候,我们给form元素添加类名.track,此时,其会自动上报表单是否填写完全成功,:invalid和:valid都是标准的原生的CSS伪类选择器,我们无需自己写验证逻辑。

JS如下:

forms.addEventListener('submit', function (event) {

event.preventDefault();

// 上报成功与否

this.classList.add('track');

// 这个是不影响原生表单的提交行为,实际开发多走Ajax

if (this.reportValidity()) {

this.submit();

}

setTimeout(function () {

this.classList.remove('track');

}.bind(this), 0);

});

web前端开发学习Q-q-u-n: 767273102 ,分享开发工具,零基础,进阶视频教程,希望新手少走弯路

HTML这里也需要novalidate属性配合下:

眼见为实,您可以狠狠地点击这里:表单验证出错与数据上报demo

6477c42f69fec43a0110cdab4c5f4c98.gif

不过,这种方法有个缺陷,无论成功与失败,只能上报一次。

表单的reportValidity()方法虽然很省力,但是会呼起浏览器原生的提示,过不了设计师那一关的,因此,恩,大家high一下即可。

二、纯CSS实现HTML验证与提示

再说说另外一个纯CSS应该,那就是进行HTML验证,并且直接在页面上输出来。

举个简单例子,图片如果空alt属性,则高亮这个图片:

img[alt=""] { outline: 2px solid red; }

又或者_blank链接的rel属性没有加noopener和noreferrer。

a[target="_blank"]:not([rel="noopener noreferrer"]) { outline: 2px solid red; }

诸如此类。

然后配合伪元素在页面上显示提示的文字:

script[src]:not([async]) {

display: block;

}

script[src]:not([async])::after {

content: '试试给带有[src="…"]的元素添加[async]属性';

}

web前端开发学习Q-q-u-n: 767273102 ,分享开发工具,零基础,进阶视频教程,希望新手少走弯路

使用很简单,你的项目引入这个CSS,那些使用有问题的HTML就会标记并提示,类似下面截图:

c46288c6399af94b46ef5f503561ed43.png

然而,有些提示嘛,咳咳,有些牵强附会了,大家当新闻八卦看看就好了。

三、为什么说是蛋疼应用

本文提到的两个CSS的新奇应用,怎么说呢,有点像手工耿哥的的各种手工作品,很有新意,很有特色,可惜,并不实用。

比方说一开始的数据上报,局限很大,很多行为你无法统计;另外维护非常不方便,把一大堆URL地址塞到CSS中,回头要是改个什么东西,很啰嗦的。CSS是偏前前端的玩具,而数据上报偏后的前端更合适,实际开发肯定不会这么玩的,人力资源利用完全没有最大化嘛。

还有那个HTML验证,这年头,还有谁关心HTML语义,结构啥的嘛,小程序,Vue这种HTML结构都是自定义的,和标准越走越远了,没有市场,就没有价值。而且里面很多验证,有些想得太多,空div为什么就不能存在呢?我就想不通了。

标签:url,gif,HTML,上报,pixel,CSS

来源: https://blog.csdn.net/llll789789/article/details/97823191

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值