by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11116 鑫空间-鑫生活
本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。
MicroData微数据相关的知识适用于对SEO非常重视的产品,且主要针对谷歌、微软、雅虎等国外的搜索引擎,适用场景较为小众,因此,本文内容大致了解下即可。
所谓微数据,就是在原有的HTML元素基础上,通过设置若干专门给机器识别的HTML属性,让搜索引擎可以更好地理解这一块的数据。在具体展开介绍之前,有必要先介绍https://schema.org/这个网站,准确说这是一个开源协作的社区组织,由谷歌、微软、雅虎和Yandex创建,致力于在互联网、网页、电子邮件等平台上创建、维护和推广结构化数据的模式。
由于大厂的支持和社区的推动,schema.org网站所共享的词汇表已经成为某种实时标准,超过1000万个网站使用schema.org定义的微数据结构来开发网页、发送邮件等,大家如果有兴趣,也可以前往对应的Github项目(https://github.com/schemaorg/schemaorg)参与共享,目前已经发布了24个版本了。
既然是规范,那必然意味着不能随便使用。例如,微数据只能对特定的物体或事件进行描述,并不能随便自定义。至于哪些物体和事件可以用,就需要看有没有对应的词汇表了。
schema.org网站上的词汇表非常多,但是我们只需要关注其中的常用词汇表即可,例如:
还有更多的词汇表,大家可以去schema.org这个网站自行搜索,其中,每一个词汇表都对应一个在线的网站,这个在实际应用的时候是必不可少的。例如介绍的信息是某个人物,同时希望搜索引擎可以准确知道人物的各个信息,那就需要在外部容器元素上将itemtype的属性值设置为https://schema.org/Person
,也就是人物的词汇表。
<div itemscope itemtype="https://schema.org/Person"> <!-- 里面是人物头像、名称等HTTML信息 --> </div>
这样,浏览器才能准确抓取该人物的微数据结构,才能更好地理解这部分的HTML信息,随后才能在搜索引擎结果页面更好地展示结果,自然会有更高的点击率,同时,根据已知的政策,数据结构越高的内容排名会更高,从而进一步提高了点击率。这些都是免费的引流资源,做得好可以给公司省很多钱的。
好,理解了基本概念,下面轮到主角出场了,专门用来实现微数据结构的itemid
、itemscope
、itemhref
、itemtype
、itemprop
这5个以item开头的HTML属性。
与微数据结构相关的HTML属性有5个,均是以item开头,先来说说itemid
。
在微数据结构中,itemid
属性非必须的,也就是就算不设置也不会影响微数据结构的识别,通常无需设置,只有当同一个页面有多哥模块使用同一个数据源的时候才需要指定,例如,某员工信息页面,页面侧边框展示的是用户自己的职员信息,然后页面主区域是员工信息列表模块,既然用户自己也是员工,那很自然就有概率员工自己也会出现在此列表中,于是,一个页面就会出现两个相同的个人信息展示,此时,就可以通过设置相同的itemid
值,让机器知道这里其实是同一个人员信息,使获取的数据结构更加精准。
从这个例子可以看出,itemid
属性的作用和id
属性完全不同,前者的性质更类似于同类识别,而后者是唯一标识符区分,但是,如果你查看itemid
属性的规范文档,会看到这么一句:
The itemid attribute, if specified, must have a value that is a valid URL potentially surrounded by spaces.
意思是,itemid
属性的值只能是合法的URL地址,然而,实际上,无论是浏览器、搜索引擎,亦或者schema官方提供的微数据验证器(https://validator.schema.org/),都没有遵循这条规范,你使用普通的字符串作为itemid
属性的值也会认为是合法的,例如,有如下所示的HTML代码:
<aside> <div itemscope itemtype="https://schema.org/Person" itemid="zhangxinxu"> <span itemprop="name">张鑫旭</span> <img src="zhangxinxu.jpg" itemprop="image" alt="头像"/> <span itemprop="jobTitle">前端开发</span> <span itemprop="telephone">13208033***</span> <a href="mailto:zhangxinxu@zhangxinxu.com" itemprop="email">zhangxinxu@zhangxinxu.com</a> </div> </aside> <main> <h2>技术部人员列表</h2> <div itemscope itemtype="https://schema.org/Person" itemid="wumingshi"> <span itemprop="name">吴明士</span> <img src="wumingshi.jpg" itemprop="image" alt="头像"/> <span itemprop="jobTitle">客户端开发</span> </div> <div itemscope itemtype="https://schema.org/Person" itemid="zhangxinxu"> <span itemprop="name">张鑫旭</span> <img src="zhangxinxu.jpg" itemprop="image" alt="头像"/> <span itemprop="jobTitle">前端开发</span> </div> </main>
粘贴到schema官方提供的微数据验证器中进行验证,可以看到验证成功,同时,仅会输出两条人员信息数据结构,虽然有三段HTML应用了Person词汇表,如图所示。
另外,itemid
属性必须和itemscope
和itemtype
属性同时使用才是合法的。
itemscope
属性用在微数据结构的最外层,相对于告诉搜索引擎,从我开始,会有一段独立的微数据结构,所以,这个属性是个布尔属性,有或者没有,例如:
<div itemscope itemtype="https://schema.org/Person"> <span itemprop="name">张鑫旭</span> <img src="zhangxinxu.jpg" itemprop="image" alt="头像"/> <span itemprop="jobTitle">前端开发</span> </div>
另外,itemscope
属性必须和itemtype
属性或者itemhref
属性同时设置才合法。
itemtype
属性用来指定微数据结构的词汇表,例如,上面的例子中,就是使用了Person词汇表,这个属性的值可以是任何一个词汇表,例如,下面的例子中,使用了Product词汇表,表示一个产品:
<div itemscope itemtype="https://schema.org/Product"> <span itemprop="name">iPhone 12</span> <img src="iphone12.jpg" itemprop="image" alt="iPhone 12"/> <span itemprop="price">5999</span> <span itemprop="priceCurrency">CNY</span> <span itemprop="description">iPhone 12是苹果公司于2020年10月发布的一款智能手机</span> </div>
另外,itemtype
属性必须和itemscope
属性同时设置才合法。
itemprop
属性用来指定微数据结构的某个属性,不同的词汇表使用的值是不一样的,想要知道当前的词汇表支持哪些itemprop
属性的值,可以去对应的词汇表页面查找,例如人物的词汇表是https://schema.org/Person,于是就可以访问该页面,可以看到如下图所示的表格,其中左侧第一列就是支持的属性值。
由于人也属于物体,因此,Person词汇表支持的部分属性名称是继承于Thing词汇表的,例如name(姓名)、image(图像)、description(描述)等,具体不展开,大家也无需记忆,需要用到的时候,去对应的词汇表寻找,或者参考使用案例修改修改。
众所周知,我们日常看到的href属性值都是以URL地址为主,但是itemhref
属性却不同,其属性值是其他元素的id
值,且支持多个值,以空格分隔,例如:
<div itemscope id="amanda" itemref="a b"></div> <p id="a">姓名:<span itemprop="name">阿曼达</span></p> <div id="b" itemprop="band" itemscope itemref="c"></div> <div id="c"> <p>乐队:<span itemprop="name">爵士乐队</span></p> <p>规模:<span itemprop="size">12</span>名成员</p> </div>
通常的微数据结构为嵌套结构,也就是itemscope
所在的元素是整个数据结构的最外层,但是,实际的Web应用场景千千万,总会因为布局等方面的原因,导致我们的HTML数据结构无法嵌套使用,而是相邻的DOM层次结构,此时,就可以使用itemref
属性让非嵌套的HTML元素依然有符合要求的微数据结构,正如上面的案例所示的这般。
和itemtype
属性一样,itemhref
属性必须和itemscope
属性一起使用才合法,以及itemhref
属性并非微数据结构模型的一部分,更像是一种语法结构,用于帮助作者向不方便添加注释的树结构添加注释。
总的来说,微数据结构的5个HTML属性,itemid
和itemhref
这两个属性不常用,itemscope
的使用方式固定,最需要关注的其实就是itemtype
和itemprop
属性,查找官方词汇表,在现有的HTML结构基础上进行属性值的设置,随后SEO和其他一些机器设备的识别就会增强了。
不过,国内目前对微数据结构的关注并不多,国内的软硬件产品也并未遵循这套语言规范,因此,是否在实际项目中使用微数据结构,我持中立态度,不推荐也不反对,看个人追求和产品的受众群体吧。
最后再啰嗦两句,其一,本文为明年即将出版的HTML书籍(书名暂时保密)部分节选的初稿,由于自己写得很不满意,又不想浪费,就放出来充一篇文章数。
其二,今年春节就不更新文章了,我后天周五就休假了,请了4天年假,哈哈哈,钓鱼钓high天,可以关注我的抖音账号“最会钓鱼的程序员”,记录钓鱼生活。
本文为原创文章,欢迎分享,勿全文转载,如果实在喜欢,可收藏,永不过期,且会及时更新知识点及修正错误,阅读体验也更好。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11116
(本篇完)