`
Sweblish
  • 浏览: 101005 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

URL设计准则

 
阅读更多
URL设计准则

  

  URL 设计是 Web 设计中常被忽视的东西,事实上 URL 非常重要,这不仅是一个网页唯一的路径,还涉及到你的站点是否干净,友好。本文讲述 URL 这个司空见惯的 Web 元素中包含的大量不应为忽视的知识,准则与最佳实践。需要注意的是 W3C 建议使用 URI 取代 URL 一说。

  关于 URL 的一些准则

  首先是与 URL 有关的一些准则。

  一个 URL 必须唯一地,永久地代表一个在线对象

  URL 的最基本的使命是唯一地代表 Internet 上的一个对象,URL 必须和 Internet 上的对象一对一匹配。然而现实中,这很难实现,我们经常可以通过多个 URL 到达同一个页面,比如, http://mysite.com/product/tv 和 http://mysite.com/product?name=tv,这种情形在现代 CMS 中更是比比皆是,针对这个问题,SEO moz 有一篇很好的文章,讲到了如何使用 Canonical URL 机制解决站点中的重复 URL 问题。

  URL 应该是永久的,这就要求你在站点上线前就非常严谨地规划 URL。如果有一天,你不得不更改 URL,一定使用 HTTP 301 机制,告诉浏览器和搜索引擎,你的那个 URL 所代表的对象,已经搬迁到新地址,这个机制可以保证你旧地址所获得 PR 不会被清零。

  尽可能用户友好

  这是 URL 设计的根本,你的 URL 应该为最终用户而设计。保持 URL 友好的一个好办法是在保证可读性的同时让它尽可能短。比如 /about 就好过 /about-acme-corp-page,当然,保持简短不能牺牲可读性, /13d2 一类的地址短则短矣,但并不友好。如果要在 Twitter, Facebook 一类的社会媒体网络分享你的 URL,可以使用 Bit.ly 一类的网址缩短工具,但这种工具产生的缩短 URL 并不友好,在 WordPress 一类的 CMS 中,可以使用 PrettyLink Pro 或 Short URL plugin 一类的可控制的地址缩短插件。

  
\



  URL 的设计切忌使用一些对用户来说没有意义的内容,比如数据库的 ID 号, /products/23 这样的 URL 地址对用户是极不友好的,应当使用 /products/ballpoint-pen 一类的地址。

  保持一致性

  站点内的所有 URL 必须保持一致的格式和结构,这样可以为用户带来信任感,如果你必须更改 URL 格式和结构,需要使用 HTTP 301 机制。

  可预测的 URL

  这也是 URL 一致性的一个表现,如果你的 URL 拥有很好的一致性,用户可以根据 URL 猜测别的内容的 URL,假如 /events/2010/01 指向 2010 年 1 月份的日程内容,那

  /events/2009/01 应当指向 2009 年 1 月的日程。

  /events/2010 应当指向 2010 年全年的日程。

  /events/2010/01/21 应当指向2010年1月21日的日程。

  URL中的关键词

  URL 中应该包含本页重点内容的关键词,比如 /posts/2010/07/02/trip-best-buy-memory-cards 一类的 URL 本身就是对页面内容的反应。在 URL 包含重点内容关键词,也可以提高 SEO 性能。SEO 的一个很重要的原则就是,在 URL 地址中包含内容关键词。

  关于 URL 的技术细节

  下面说的是有关 URL 的一些技术细节。

  URL 不应包含 .html, aspx, cfm 一类的后缀

  这类信息对最终用户是没有意义的,却占了额外的空间,一个例外是 .atom, .rss, .json 一类的特殊地址,这类地址是有特别的意义的。译者注:在某些虚拟主机式 Web 服务器,这种做法未必现实。

  URL 不应包含 WWW 部分

  WWW 部分并不包含任何意义,是一个额外的负担,不友好。可以使用 HTTP 301 机制,将 www.domain.com 定向到 domain.com 。

  URL 的格式

  URL 的格式如下:

  domain.com/[key information]/[name]/?[modifiers]

  Key information 部分一般代表信息的类型或类别。Modifiers 部分则属于查询字符串范畴,它不应当代表数据结构,应当代表数据的修饰。Key information 部分应当尽可能简短,同时应当表现出一种层级关系,比如 http://domain.com/posts/servers/nginx-ubuntu-10.04,或 http://domain.com/news/tech/2007/11/05/google-announces-android。

  Google News 对新闻源有一个有趣的要求,Google 要求新闻源页面的 URL 中必须包含至少 3 位唯一的数字,因为他们会忽略年份数字,因此,应该使用一个5位或5位以上的数字。另外,也应该提供 Google News 站点地图 。如果你想向 Google 提供新闻,必须按这样的结构提供 URL,当然保持一致性,可以预测性也是必需的。

  使用小写字符

  URL 中所有字符都应使用小写,这更容易阅读。

  URL 中包含的行为元素

  URL 查询字符串中可能包含一些表示行为的元素,比如 show, delete, edit 等。非破坏性的行为可以体现在 URL 中,破坏性的行为应该使用 POST 。

  使用 URL 友好字符

  在 URL 中体现网页标题的时候,往往会用到一些特殊字符,应当把它们转换为 URL 友好字符:

  全部大写字符换成小写

  诸如 é 一类的字符应转换成对应的 e

  空格使用短划线代替

  诸如 !, @, #, $, %, ^, &, * 一类的字符应该使用短划线代替

  双短划线应该使用单短划线代替

  另外,没有必要的话,避免使用 %20 一类的 URL 逃逸符。

  译者补充:URL 的长度上限

  URL 的最大长度是多少?W3C 的 HTTP 协议 并没有限定,然而,在实际应用中,经过试验,不同浏览器和 Web 服务器有不同的约定:

  IE 的 URL 长度上限是 2083 字节,其中纯路径部分不能超过 2048 字节。

  Firefox 浏览器的地址栏中超过 65536 字符后就不再显示。

  Safari 浏览器一致测试到 80000 字符还工作得好好的。

  Opera 浏览器测试到 190000 字符的时候,还正常工作。

  Web 服务器:

  Apache Web 服务器在接收到大约 4000 字符长的 URL 时候产生 413 Entity Too Large” 错误。

  IIS 默认接收的最大 URL 是 16384 字符。

转载地址:http://www.php100.com/html/itnews/it/2011/1227/9558.html
分享到:
评论

相关推荐

    SaturnFresh:电商综合课程设计准则

    电商综合课程设计准则 运行要求 Django> = 3.0 pymysql> 0.10.0 python> 3.5 mysql> 8.0 简单的命令说明 python manage.py createsuperuser #创建一个可以登录后台的用户 python manage.py runserver #启动服务...

    http-api-design:HTTP设计准则

    HTTP API设计标准 指导方针 本文档提供了GoCardless API的准则和示例,以鼓励一致性,可维护性和最佳实践。 资料来源: JSON API 所有端点必须遵循核心 对JSON API的更改: 主资源必须通过其资源类型进行键控。 ...

    FABRevealMenu-master:一个通用的android UI库,用于根据材料设计准则的浮动操作按钮显示用户显示菜单

    它结合了棒棒糖圆形揭示视图和一些酷炫的动画,这些动画有些受到Google材质设计指南启发使用Google提供的来自材料组件的。 gradle依赖步骤1.将其添加到存储库末尾的root build.gradle中: allprojects { ...

    WEB设计大全

    <br>5.2.1 Web上的精确定位:URL <br>5.2.2 网页和站点标签 <br>5.2.3 网页、站点的样式和位置 <br>5.2.4 我曾到过哪? <br>5.3 我能去哪? <br>5.4 导航位置 <br>5.4.1 顶部导航 ...

    URL-Shortener:Picchi URL-LongURL缩短器

    Picchi URL-LongURL缩短器 将长链接短成短链接并轻松跟踪它们 科技栈 前端:NextJS,Tailwind 后端:nestJS 服务器:Vercel(前端)和VPS(后端) 问题 随时提交问题和增强要求。 贡献 请参考每个项目的样式和贡献...

    lop.si:使用TypeScript中的Next.js,ThemeUI,Firebase和wirtten制作的简单的亚态URL缩短器

    设计受同态影响很大 :sparkles:产品特点暗/亮模式。 创建的url只有11个字符长,其中4个是url的id 。 干净的用户界面React灵敏高绩效贡献在对该存储库做出贡献时,请先通过发行,电子邮件或其他任何方法与该存储库的...

    android-navigation-bar:Flarebar是一个android库,用于在您的android应用程序中添加现代导航栏

    Flarebar是完全可自定义的导航栏,遵循现代材料设计准则。 它是新设计的底部栏(也可以用作顶部导航栏)。 具有不同设计的演示 设计#1 设计#2 设计#3 标签徽章 选择后 安装 将其添加到存储库末尾的root build....

    WEB设计大全(part2)

    <br>5.2.1 Web上的精确定位:URL <br>5.2.2 网页和站点标签 <br>5.2.3 网页、站点的样式和位置 <br>5.2.4 我曾到过哪? <br>5.3 我能去哪? <br>5.4 导航位置 <br>5.4.1 顶部导航 ...

    Access 2000数据库系统设计(PDF)---002

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---018

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---003

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---011

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---020

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---009

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---012

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---015

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---027

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---025

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---026

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

    Access 2000数据库系统设计(PDF)---029

    1778.1 查询简介 1778.2 “简单查询向导”的使用 1778.3 使用查询设计窗口 1798.3.1 为查询选择字段 1808.3.2 按准则选择记录和排序显示 1828.3.3 创建更为复杂的查询 1838.3.4 改变查询列标题的名字 1848.3.5 将...

Global site tag (gtag.js) - Google Analytics