我最近开始深入研究 RDFa,并尝试用语义信息为我的网站增添趣味。该网站提供服务、事件、博客,并可能在未来提供产品。幸运的是 schema.org 有粗略但足够的类别。但现在涉及到实际问题。
所有示例都在一个页面上提供了所有信息,这对我来说似乎很学术。例如。在我的登陆页面上是一个包含即将发生的事件的列表。事件有一个位置属性。我的事件在 2 个不同的地点举行。我可以粘贴每个条目的位置信息并扩充我的 html。我宁愿链接到描述位置并包含完整详细信息的页面。不确定,这是否是 sameAs 的用途。但即便如此,它又如何知道目标 URL 上的哪些 RDFa 信息应该用作合适的 vCard?
同样,我的着陆页只有部分公司信息可见。我可以添加很多 <meta> , 但再次引用联系页面会很好。
我只是不想相信 RDF 的创建者会忽略这个方面。是否有任何减少冗余的最佳做法?
最佳答案
URIs!(或 IRIs,例如 RDFa 1.1)
这是 RDF 的主要品质之一,它使 Linked Data可能,如coined by Tim Berners-Lee (强调我的):
The Semantic Web isn't just about putting data on the web. It is about making links, so that a person or machine can explore the web of data.
Like the web of hypertext, the web of data is constructed with documents on the web. However, unlike the web of hypertext, where links are relationships anchors in hypertext documents written in HTML, for data they links between arbitrary things described by RDF
From my answer to a question about the Semantic Web :
Use RDF (in the form of a serialization format of your choice) and define URIs for your entities so that you and other people can make statements about them.
因此,为您的所有“实体”提供一个 URI,并将其用作主题响应。 RDF 三元组中的对象。请注意,您可能不想使用与您的网页相同的 URI,因为这样很难区分有关网页的数据和有关网页所代表事物的数据(请参阅 my answer describing this in more detail)。
假设您的网站有以下两个页面:
http://example.com/event/42(关于事件 42,即 HTML 页面)http://example.com/location/51(关于位置 51,即 HTML 页面)使用 hash URI方法,您可以创建这些 URI:
http://example.com/event/42#it(事件42,即真实事件)http://example.com/location/51#it(位置 51,即真实的东西)现在,当您想使用 Schema.org 词汇表来提供有关您的事件的信息时,您可以使用 resource给出它的 URI:
<!-- on http://example.com/event/42 -->
<article resource="#it" typeof="schema:Event">
<h1 property="schema:name">Event 42</h1>
</article>
当您想指定事件的位置(使用 Place)时,您可以使用位置的 URI:
<!-- on http://example.com/event/42 -->
<article about="#it" typeof="schema:Event">
<h1 property="schema:name">Event 42</h1>
<a property="schema:location" typeof="schema:Place" href="/location/51#it">Location 51</a>
</article>
在位置页面上你可能有这样的东西:
<!-- on http://example.com/location/51 -->
<article about="#it" typeof="schema:Place">
<h1 property="schema:name">Location 51</h1>
<a property="schema:event" typeof="schema:Event" href="/event/42#it">Event 42</a>
</article>
汇总这些数据,您将拥有这些三元组(在 Turtle 中):
@prefix schema: <http://schema.org/> .
<http://example.com/location/51#it> a schema:Place .
<http://example.com/location/51#it> schema:event <http://example.com/event/42#it> .
<http://example.com/location/51#it> schema:name "Location 51" .
<http://example.com/event/42#it> a schema:Event .
<http://example.com/event/42#it> schema:location <http://example.com/location/51#it> .
<http://example.com/event/42#it> schema:name "Event 42" .
编辑:我不确定(我希望不是这种情况),但也许 Schema.org 需要一个带有 url(或 sameAs? ) 属性,例如:
<article about="#it" typeof="schema:Event">
<h1 property="schema:name">Event 42</h1>
<div property="schema:location" typeof="schema:Place">
<a property="schema:url" href="/location/51#it">Location 51</a>
</div>
</article>
关于seo - RDFa DRY 引用的概念,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23616946/
我需要在rail3中使用标准注册/登录/忘记密码功能进行身份验证。是否有大多数人为此使用的插件或其他东西? 最佳答案 我不确定最常用的方法是什么-但可以肯定的是,Plataformatec的“Devise”是一个非常流行的方法:http://github.com/plataformatec/devise我已经尝试了一些authgem,对我来说,它是最简单的设置和修改以满足我的需要。它内置了密码恢复、帐户确认(如果需要)和其他一些非常方便的功能。 关于ruby-on-rails-在Rail
我在ruby表单中有一个提交按钮f.submitbtn_text,class:"btnbtn-onemgt12mgb12",id:"btn_id"我想在不使用任何javascript的情况下通过ruby禁用此按钮 最佳答案 添加disabled:true选项。f.submitbtn_text,class:"btnbtn-onemgt12mgb12",id:"btn_id",disabled:true 关于ruby-on-rails-如何在Rails中添加禁用的提交按钮,我们在St
关闭。这个问题是off-topic.它目前不接受答案。想改进这个问题吗?Updatethequestion所以它是on-topic用于堆栈溢出。关闭11年前。Improvethisquestion我不经常使用ruby-通常它加起来相当于每两个月或更长时间编写一次脚本。我的大部分编程都是使用C++进行的,这与ruby有很大不同。由于我与ruby之间的差距如此之大,我总是忘记语言的基本方面(比如解析文本文件和其他简单的东西)。我想每天练习一些基本的东西,我想知道是否有一些我可以订阅的网站,并且会向我发送当天的Ruby问题或类似的东西。有人知道这样的站点/Internet服务吗?
目录一、什么是Websocket二、WebSocket部分header介绍三、HTTPVSWebSocket四、什么时候使用WebSockets五、关于SockJS和STOMP一、什么是Websocket根据RFC6455标准,Websocket协议提供了一种标准化的方式在客户端和服务端之间通过TCP连接建立全双工、双向通信渠道。它是一种不同于HTTP的TCP协议,但是被设计为在HTTP基础上运行。Websocket交互始于HTTP请求,该请求会通过HTTPUpgrade请求头去升级请求,进而切换到Websocket协议。请求报文如下:GET/spring-websocket-portfoli
ChatGPT掀起了AI股历史上最疯狂的一轮市值狂飙。自春节后至今,ChatGPT概念股开始了暴走模式,短短半月时间,海天瑞声、开普云等ChatGPT概念股市值累计增加了近1400亿。如此的爆炸效应,得益于ChatGPT所展现出商业化落地的巨大潜力。要知道,在此之前,无论是十年AI投入超千亿的百度,还是困在硬件化里的AI四小龙,都在重复着AI商业化难落地的故事。ChatGPT的出现,让AI从生产力的赋能者直接成为一种创造生产力的工具。随着订阅模式的推出,ChatGPT已经成为第一个以AI技术为核心直接变现的消费者应用。本文持有以下核心观点:1、ChatGPT是AI技术迭代的受益者。过去受限技术
谁能告诉我如何在ruby中获取可用磁盘驱动器的列表?我正在创建一个打开的文件对话并且需要知道!提前致谢,嗯。 最佳答案 Brian给出的文章正确地陈述了以下代码:require'win32ole'file_system=WIN32OLE.new("Scripting.FileSystemObject")drives=file_system.Drivesdrives.eachdo|drive|puts"Availablespace:#{drive.AvailableSpace}"puts"Driveletter:#{drive.D
我刚刚开始将InheritedResources用于我正在构建的应用程序,当我查看它的Github页面时,它说它已被弃用,我应该改用Responders。我是InheritedResources和Responders的新手,所以我很困惑,当我从文档中看到的只有FlashResponders和HTTPCacheResponders时,我如何从Responders获得我在InheritedResources(完整的REST操作基础"template"代码)中获得的内容?我也看过这个:http://blog.plataformatec.com.br/tag/inherited_resourc
我有许多在所有Rails项目中使用的gems,但它们不是项目Gems的一部分,例如用于管理POW的powder。使用全局Gemfile管理它们对我来说很有意义,但我看不到任何示例。我应该如何管理项目gemfile中不需要的全局Gem?当我设置一台新机器等时,最好有一个安装点。我使用chruby和ruby-install来管理我的Ruby版本。 最佳答案 像往常一样制作一个Gemfile,并将其放在任何文件夹中。它不需要是项目文件夹。然后你可以这样做:bundleinstall--system这将在Gemfile系统范围内安装ge
有没有一种快速的方法来跟踪在对象上调用的方法?通常,当我在gem的公共(public)界面之下的级别上工作时,我会遇到难以追踪的错误。最终,我最终通过源代码跟踪对象并将所有内容都记在脑海中。但是,如果能够在对象上调用类似#log_method_calls的东西,那么,比如说,调用它的所有方法都会打印到stdout或其他东西。有什么办法可以做到这一点? 最佳答案 有几种方法可以做到这一点,视情况而定。如果可以创建一个新对象而不是被观察对象,您可以使用method_missing轻松编写一个观察者类。classLogProxydefin
我刚刚经历了这个概念Zero-WidthAssertions从文档中。我想到了一些快速的问题-为什么这样的名字Zero-WidthAssertions?Look-ahead怎么了和look-behind概念支持这样的Zero-WidthAssertions概念?什么这样的?,,=s,-4个符号在模式内指示?你能帮我集中精力了解实际发生的事情我还尝试了一些小代码来理解逻辑,但对它们的输出没有那么自信:irb(main):001:0>"foresight".sub(/(?!s)ight/,'ee')=>"foresee"irb(main):002:0>"foresight".sub(/(?