web页面uri唤醒应用_带有数据URI的高性能Web设计

web页面uri唤醒应用

我们最近在Webdesigntuts +上介绍了Web设计中的数据URI的内容,原因和方式 ,在其中研究了使用数据URI进行性能友好的界面设计的一些可能性。

在今天的Premium教程中,我们将采用介绍性文章中介绍的一些理论,以一些用于开发完全实现的用户界面的示例为基础。 为了使事情有趣,我们还将使我们的设计具有响应性,并且将使用Dribbble API和jQuery从Envato Dribbble feed中提取一些图像。

有很多要讲的内容,所以让我们开始吧!


开始之前

正如我已经提到的那样,本教程基于Web设计教程中的数据URI的内容,原因和方式 。 即使您对数据URI的了解已经扎实,我还是强烈建议您在开始此处之前先阅读本文。 我将使用初始文章中的练习中的一些代码来节省时间,因此,我将要求您在以下几点上跳回到原始文章。

其次,在该项目中,我们将严重依赖数据URI,以便为您提供大量使用此技术的实践。 是否实际在生产中大量使用数据URI还是有争议的(尤其是如果支持

最后,该项目在Webkit,Firefox和Internet Explorer的最新版本中进行了测试。 您可以放心地假定此接口在IE7及以下版本中将无法完全发挥作用(尽管如果需要,可以很容易地将后援应用于旧版IE版本)。 此外,在本教程中,我将引用-webkit和CSS3元素的通用前缀,但是源文件将包含所有供应商前缀。


关于数据URI的两分钟回顾

在开始破解之前,让我们快速回顾一下数据URI方案是什么,以及为什么它可以作为向浏览器提供元素的好选择,这些元素通常会消耗资源并降低性能。

  • 数据URI是一种将二进制数据编码为ASCII文本字符串的方式,现代浏览器可以读取和呈现该字符串。
  • 数据URI通常用于替换图像文件,但是可以对任何二进制数据进行编码,包括SVG,多媒体,字体等。
  • 使用数据URI的主要好处是减少了在浏览器窗口中加载页面所需的HTTP请求数量。 简而言之,每增加一个HTTP请求(通常)都会对网站的整体性能产生负面影响。
  • 数据URI比标准文件类型(例如JPG图像)大33%左右,但通过压缩和gzip压缩,该数量通常减少到5%以下。 这个额外的文件大小通常不是一个大问题,但是在选择最佳技术以将资产包含到设计中时要牢记这一点。
  • 数据URI冗长,毫无意义,看起来也不是很漂亮,使得标记和样式表难以阅读,浏览和维护。 最好在文本编辑器中使用代码折叠!

进攻计划

本教程将分为三个单独的阶段,我们将按以下顺序进行处理:

  1. 使用HTML和CSS中的参考图片设计“全角”网站。
  2. 从Dribbble API和jribbble jQuery插件中提取图像
  3. 添加媒体查询以使站点在较小的视口中响应。

好的! 聊够了! 让我们开始编码吧!


步骤1:初始标记

对于我们的设计,我们将以最新HTML5 Boilerplate作为起点。 我们不会在项目中使用样板的所有功能(例如,现代化脚本或分析),但是最好在初始阶段保持“原样”,然后在项目后期返回以减少我们最终没有使用的功能(或者将来可能不会使用)。

在还包含css和js文件夹的目录中创建一个新的index.html文件。

在文档的中,添加

,精选内容
我们将继续进行充实。



    
        Albireo: Designing With Data URIs

        


    
    
        

接下来,让我们使用Eric Myers CSS Reset重置CSS并添加一些基本的布局样式:

* {
    /* Give all elements box-sizing of border-box
    (Total width = width + margin + padding + border) */
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

body {
  margin:0;
  padding:0;
  background-color: #eee;
}

header {
  height: 80px;
  margin:0;
  padding:0;
  position: relative;
  background-color: #3C3C3C;
}

.featured-content {
  margin-top: 4%;
}

footer {
  border-top: 1px solid #eee;
  width:100%;
  min-height: 80px;
  background-color: #ccc;
  margin-top: 0;
  text-align: center;
  padding-top:21px;
}

除了border-box框模型的通用应用之外,这里的所有内容都应该相当简单。 在此,代替使用将填充,边距和边框分别添加到元素的定义宽度的标准框模型,定义的宽度是元素的总宽度,包括填充,边距和边框。

这种方法在可变布局中很流行,许多流行的框架都使用border-box模型,包括Twitter Bootstrap和Zurb Foundation,因为它使处理百分比无效的工作变得容易。 是否需要等宽的列,每列之间有沟槽? 简单。 只需应用Boder-Box模型并将该列设置为33.333%-无需分别计算填充和边距。

当然,到目前为止没有什么可看的,这只是我们的画布!


步骤2:定义简单的流体网格

如果看一下该演示,您将看到精选内容将被布置在三个等宽列中。 在幕后,这些列位于

其中的类为设置居中内容区域,最大宽度为1024px。

为了使我们的项目顺利进行,让我们在CSS中定义这个简单的网格(部分改编自Zurb Foundation 3.1 ):

.row {
  width:1024px;
  margin:0 auto;
  max-width: 100%;

  /* Prevent child elements scaling down further once the viewport hits 767px */
  min-width: 767px;
  background-color: transparent;
}

.row:after {
  /* Clearfix applied since columns are floated */
  content: "";
  display: table;
  clear: both;
}

.row .three {
    /* Remember that the width of this element is the total of the defined width + padding + margin + border */
    width: 33.33333%;
}

.column, .columns {
    float: left;
    min-height: 1px;
    padding: 0 15px;
    position: relative;
}

在继续之前,让我澄清一下这段代码中的几点。 首先,您会看到我们对行应用了min-width 767px。 这意味着,在小于此宽度的视口上查看时,任何子元素(即.row .three )都将停止缩放,以防止特色内容项变得太小。 在本教程的稍后部分,我们将重新介绍媒体查询,以为浏览器提供有关视口何时小于767像素宽的其他说明。

其次,因为我们知道每一行都将包含浮动的子元素,所以我们需要在结束行div标签之后清除所有浮动。 在这个项目中,我将clearfix hack应用于了row:after伪元素。 如果你打算建立这个项目了,你可能需要额外clearfixes,只是追加了.row:after有一个附加的类的规则.clearfix:after


步骤3:定义版式和图标字体

尽管我们还没有使用过任何字体,但我更喜欢在样式表的顶部建立我的字体(尽管没有什么可以阻止您稍后再处理)。 为了使我们可以直接进入设计而无需回溯,现在让我们为字体和图标字体设置所有基本规则。

对于自定义的base64编码图标字体,我们将使用出色的IcoMoon应用程序生成图标字体集和所需CSS。 有关屏幕截图的完整演练,请参阅Data URI教程 。

总结一下,使用IcoMoon应用程序 ,创建以下图标字体:

  • 选择一个自定义集,其中包括Broccolidry系列中的“心脏”,“眼睛”,“评论”和“放大镜”图标。
  • 将基准设置更改为10%
  • 在“更多设置”下,将字体名称更改为“ customFont”
  • 选中“ Base64在CSS中编码和嵌入字体”复选框

下载字体,打开主样式表,然后将CSS复制到项目的style.css文件中。

除一些其他字体样式外,样式表的“版式”部分还将包含以下代码:

p, a, h1, h2, h3, h4, h5, h6, li {
  font-family: sans-serif;
}

a {
text-decoration: none;
}

@font-face {
  font-family: 'customFont';
  /* IE9 Compatibitly mode */
  src:url('fonts/customFont.eot');
  /* Old IE Fix */
  src:url('fonts/customFont.eot?#iefix')
}
@font-face {
  font-family: 'customFont';
  src: url(data:font/woff;charset=utf-8;base64,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) format('woff');
  font-weight: normal;
  font-style: normal;
}

/* Use the following CSS code if you want to have a class per icon */
[class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: 'customFont';
  font-style: normal;
  speak: none;
  font-weight: normal;
  -webkit-font-smoothing: antialiased;
}
.icon-search:before {
  content: "\21";
}
.icon-comment:before {
  content: "\22";
}
.icon-heart:before {
  content: "\23";
}
.icon-eye:before {
  content: "\24";
}

/* Use the following CSS code if you want to use data attributes for inserting your icons */
[data-icon]:before {
  font-family: 'customFont';
  content: attr(data-icon);
  speak: none;
  font-weight: normal;
  -webkit-font-smoothing: antialiased;
}

有关此代码的语法,其用法和旧版IE修复程序的更详细说明,请参阅Intial Data URI教程 。

现在,我们已经完成了所有基础工作,包括基本的流体网格和base64编码的自定义图标字体,让我们开始遍历每个部分并为我们的基本标记提供一些急需的修饰。


步骤4:为身体提供重复的背景

在第一个教程中 ,我们从Subtle Patterns的一幅小图像创建了一个Data URI,这对于我们网站的背景来说是完美的。 取得此base64编码的图像,并将其作为重复的background-image添加到页面的元素中。

使用以下CSS充实body规则,该CSS取自本教程前面的步骤:

body {
  margin:0;
  padding:0;
  background-image: url();
  background-repeat: repeat;
  background-color: #eee;
}

大! 现在,我们有了一个漂亮的背景图块,该图块在整个文档的y和x轴上都重复。


步骤5:标记和样式网站标题

跳回到您的标记中,并在

部分中添加以下HTML:

接下来,让我们使用重复线性渐变呈现的格子背景来设置标题背景的样式:

header {
  height: 80px;
  margin:0;
  padding:0;

  /* We'll be positioning elements absolutely inside the header shortly */
  position: relative;

  border-bottom: 1px solid #303031;

  box-shadow: inset 0px -1px 14px rgba(0, 0, 0, .6), 00px 5px 10px rgba(0, 0, 0, .1) inset, 0px 1px 1px white;

  /* Left to right linear gradient */
  background-image: -webkit-repeating-linear-gradient(45deg,
  transparent 0%, transparent 60px,
  rgba(54, 54, 54, 0.7) 60px, rgba(54, 54, 54, 0.7) 100px,
  rgba(0, 255, 199, 0.1) 100px, rgba(0, 255, 199, 0.1) 140px,
  rgba(172, 172, 172, 0.1) 140px, rgba(172, 172, 172, 0.1) 160px),

  /* Right to left linear overlayed gradient */
  -webkit-repeating-linear-gradient(-45deg,
  transparent 0%,transparent 60px,
  rgba(54, 54, 54, 0.7) 60px, rgba(54, 54, 54, 0.7) 100px,
  rgba(0, 255, 199, 0.1) 100px, rgba(0, 255, 199, 0.1) 140px,
  rgba(172, 172, 172, 0.1) 140px, rgba(172, 172, 172, 0.1) 160px);

  /* Provide a fallback background-color */
  background-color: #3C3C3C;
}

该背景是对最近在Webdesigntuts +文章中使用的技术的修改。 有关更多信息,请参考《 Webdesign中的纹理的内容,位置和方式》 。

接下来,让我们添加.svg徽标,您可以从本教程的资源部分下载该徽标。

.logo {
  width: 175px;
  height: 80px;
  margin-left: 15px;
  top: 5px;
  position: absolute;
  background-repeat: no-repeat;
  display: block;

  /* Render text invisible */
  font-size: 0;
  color: transparent;
  text-shadow: none;
}

.logo img {width:100%}

您会注意到,我将徽标作为HTML标记(带有附加的HTTP请求)中的外部.svg文件进行了引用,以实现完全可扩展的矢量解决方案。 对于真正的免费图像设计,您还可以直接在HTML本身中使用.svg文件。 要了解如何最好地做到这一点,请参阅可伸缩矢量图形(SVG)入门 。

接下来,我们将为网站设置一个简单的导航菜单:

nav {
  top: 23px;
  position: absolute;
  right: 30px;
}

nav ul li {
  display:inline-block;
  font-weight:bold;
  font-size: 13px;
}

nav ul li a {
  color:#eee;
  display:block;
  padding:10px;
  height: auto;
  border-radius: 6px;
  cursor: pointer;
  margin-right: 5px;
}

nav ul li a:hover {
  background: -webkit-linear-gradient(top, rgba(0,0,0,.4) 0%, rgba(0,0,0,0.6) 100%);
  color:white;
}

步骤6:设置简单的页脚样式

我们将暂时中断逻辑流程,并注意(非常简单的)页脚的样式,因为接下来的大部分步骤将集中在创建内容项上,我想确保我们在本节中保持势头。 将以下标记添加到HTML:

样式如下:

footer {
  border-top: 1px solid #eee;
  width:100%;
  min-height: 80px;
  background-color: #ccc;
  margin-top: 0;
  text-align: center;
  padding-top:21px;
  box-shadow: inset 0px 4px 10px rgba(0, 0, 0, .2);
}

footer a {
  color:#999;
  font-size: 14px;
  font-weight: 100;
}

完成之后,让我们回到设计的重点,即特色内容项。


步骤7:精选内容项

在本教程的下一阶段,我们将使用jQuery和Dribbble API从Dribbble中提取图像。 现在,我们将使用占位符图像并设置图像本身的一般样式。

重要的是要注意,我们的标记将很快更改以适应jQuery插件,因此不要太在意以下标记! 话虽如此,如果您不想从外部站点获取资源并提供自己的静态资产,那么这就是您将要使用的代码。

我们将设计接口,使其能够扩展,以通过复制整个

元素来容纳所需数量的图像。 我们将首先创建一个
元素,然后再将其复制五次以创建两行三个图像。

在您HTML中,直接在

标记下添加特色内容图像面板的基本标记:

总结我们在这里所做的事情,我们创建了三列等宽(33.3333%)的列。 在每列内部,我们创建了:

  • 包含图像的
    元素,
  • 锚定链接,它将带我们到其他内容(即Dribbble)
  • 链接中的span元素将定义我们的放大镜图标
  • 没有设置来源的图片标签(我们将在后续步骤中使用jQuery填充图片标签)
  • “注释”,“视图”和“喜欢”的图标字体的无序列表,已被赋予一些任意的数字值。

因为图像的放置/流对整个文档结构并不重要,所以HTML5

元素是元素的完美包装。

继续介绍内容项的样式,我们将从在内容项行的底部添加边距开始,然后为

元素设置样式。
由一个元素和两个伪元素组成,以产生一堆堆积的图像效果。

为了创建一个更好地响应水平和垂直浏览器窗口大小变化的界面,我们将使用百分比来尽可能地测量元素的宽度和高度。

设置图形元素样式和图像堆栈效果所需的代码如下:

.content-items {
  margin-bottom: 5%;
}

figure {
    /* Max height of any image at any viewport width */
  max-height: 260px;
  width: 100%;
  margin:0 auto;
  padding: 3% 3% 30px 3%;

  display:block

  /* Allow children to position themselves absolutely to the parent */
  position: relative;

  background: -webkit-linear-gradient(top, white 0%,#F3F3F3 100%);
  background-color: #fff;
  border-radius: 5px;
  border: 1px solid #C7C7C7;
}

/* Bottom-most 'stacked' image */
figure:before {
  content: '';
  height: 100%;
  width: 98%;
  margin:0 auto;
  /* Absolute position within the relatively positioned parent */
  position: absolute;

  /* Stack bottom-most */
  z-index: -2;
  top: 6px;
  left: 3px;

  border-radius: 5px;
  border: 1px solid #C7C7C7;

  background: -webkit-linear-gradient(top, white 0%,#ECECEC 100%);

  background-color: #efefef;
  box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.1);
  }

/* Top-most 'stacked' image */
figure:after {
  content: "";
 height: 100%;
   width: 99%;
  position: absolute;
  top: 3px;
  left: 1px;
  /* Stack to middle */
  z-index: -1;
  margin: 0 auto;

  border: 1px solid #C7C7C7;
  border-radius: 5px;

  background: -webkit-linear-gradient(center top , white 0%, #F3F3F3 100%) repeat scroll 0 0 #EFEFEF;

  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

现在,我们应该具有良好的堆栈效果,当浏览器窗口的大小从全角缩小到767px时,可以很好地缩放。


步骤8:创建占位符图像

接下来,让我们设置实际图像本身的样式。 在本教程的下一阶段,我们将直接用Dribbble的资源填充此区域,但现在,我们将添加一个占位符图像(灰色的Envato徽标),以确保我们的

元素不会加载图像时,图像自身会崩溃。 此外,如果以后从Dribbble提取内容时遇到任何问题,则占位符图像也将保持设计正常运行(尽管我们希望保留默认的残破图像图标,以向用户提供一些反馈,提示应该存在一个图像)。

对于占位符图像,我已经使用Web语义数据URI工具将291px x 218px .jpg图像(包含在源文件中)转换为Data URI。

从工具的输出面板中复制base64编码的字符串后,我们可以完成image元素的样式设置:

figure > img {
    max-height: 219px;
    /* Super simple responsive images */
    width: 100%;

    margin:0 auto;
    padding: 0;
    border: 1px solid #E4E4E4;

  /* Placeholder Image */
  background-position:center center;
  background-image: url();
}

通过为图像提供100%的宽度和218px的最大高度,我们可以确保在调整浏览器窗口大小时,图像保持其纵横比,同时相对于

元素进行缩放。 对于响应式媒体,有更复杂的方法,但是这种超简单的方法对于此应用程序将是很好的。

为了快速进行理智检查,到目前为止,这是第一个

元素应该具有的功能:


第9步:设置“查看更多”链接的样式

当每个图像都悬停时,半透明的叠加层以及一个放大镜将出现在图像的顶部,我们将使用我们的图标字体来创建它。

首先,让我们快速查看查看更多链接的标记:

... ...

我们将设计一个块级锚链接的样式,该链接包含100%的宽度和100%的高度跨度,并具有一类icon-search ,它将链接到我们已经建立的图标字体CSS中。

链接的代码如下所示:

a.view-more {
   max-height: 219px;
  display: block;
  position: absolute;
  z-index: 20;
  top: 3%;
  bottom: 31px;
  left: 3%;
right: 3%;
border: 1px #464646 solid;
  background-color: rgba(0, 0, 0, 0.5);
  -webkit-box-shadow: inset 0px 2px 76px rgba(0, 0, 0, .6);

  opacity: 0;
  -webkit-transition: .3s all;
}

接下来,我们将添加伪类来设置:hover:active上的链接的样式:

a.view-more:hover {
  opacity: 1;
  -webkit-transition: all 0.3s;
}

a.view-more:active {
  opacity: 1;
  background-color: rgba(0,0,0,0.7);
}

您会注意到,对于查看更多链接的大小和位置,默认情况下使用百分比。 当调整浏览器窗口的大小时,这种方法允许查看更多的链接缩放并保持良好的比率。

另外,您会注意到a.viewmore链接本身已触发转换。 尽管这本身并不能做任何事情,但是当用户将鼠标悬停然后从元素上移开时,它允许链接淡出。


放大镜跨度CSS是通过使用两个独立的类( large-iconicon-search 第一类的代码如下(我已包含在样式表的“版式”部分中):

.large-icon {
  width: 100%;
  height: 100%;
  position: absolute;
  display: block;

  font-size: 76px;
  color: rgba(255, 255, 255, 0.9);
  margin: 0 auto;

  /* Vertical and horizontal alignment */
  padding-top: 25%;
  text-align: center;

  /* Give the icon a white glow effect */
  text-shadow: 0px 0px 70px rgba(255, 255, 255, 1);
  -webkit-transition: all 1s;
}

而且,我们已经在本教程的前面部分中使用IcoMoon应用程序生成的代码为icon-search建立了CSS。 但是,只是为了刷新您的记忆,下面是相关的代码,这些代码将用作未样式化的放大图标图标:

@font-face {
  font-family: 'customFont';
  src: url(data:font/woff;charset=utf-8;base64,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) format('woff');
  font-weight: normal;
  font-style: normal;
}

/* Use the following CSS code if you want to have a class per icon */
[class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: 'customFont';
  font-style: normal;
  speak: none;
  font-weight: normal;
  -webkit-font-smoothing: antialiased;
}
.icon-search:before {
  content: "\21";
}

重要的是要注意,我们已尝试将显示和图标的样式尽可能地分开(实际上,这是我尝试在整个设计中广泛应用的内容)。 这是一个很小的项目,但是如果我们想扩展界面的范围并在设计中的其他地方重用放大镜图标,则这种面向对象的方法将降低更改图标样式的复杂性。


第10步:设置评论/赞/查看列表的样式

现在剩下要做的就是用适当的图标字体设置图标组的样式。

让我们提醒自己有关项目此部分的标记。 每个内容项都有以下无序列表:

您会注意到,尽管在上一步中为放大镜图标使用了类名,但此列表仍使用data-icon方法。 在基于类的应用程序上使用这种方法没有特别的原因-这只是使用图标字体的替代执行的好机会。 您会看到我们已经使用了IcoMoon应用程序提供给我们的Unicode来定义适当的图标。 让我们首先设置列表本身的样式:

.icon-group {
  position: absolute;
  bottom: -1px;
  right: 11px;
  z-index: 30;
}

.icon-group li {
  float: right;
  margin: 0 0 0 12px;
  color: #AAA;
}

上面代码的第一部分放置

    元素,而列表项的样式将它们浮动到右侧,内联显示元素并设置一些父级样式。 接下来,我们将为list-itemlist-number元素设置样式:

    .list-icon {
      line-height: 2;
      color:#888;
      position: relative;
      font-size: 16px;
      margin-right: 2px;
    }
    
    .list-number {
      line-height: 2;
      text-decoration: none;
      font-size: 12px;
      margin:0 2px 0 4px;
    }

    因此,我们使用了一些很酷CSS3和两种不同的图标字体实现来样式化第一个特色内容元素。 这是我们的最终内容项,其中的view-more链接处于悬停状态:

    此时,如果我们要保持接口静态(即不通过Dribbble API提取资产),我们可以根据需要简单地复制并粘贴content-items代码块多次,并引用适当的图像文件。 但是,由于我们在接下来的步骤中会做一些不同的事情,因此在讨论下一步之前,我们将暂时保留当前的标记,然后大吃一惊,到目前为止,我们的所有工作。


    步骤11:介绍Dribbble API和Jribbble插件

    对于本教程的后续步骤,我们将使用Dribbble API直接从Dribbble拍摄的镜头填充特色内容项目。

    该API允许我们通过HTTP直接从应用程序获取内容,并以JSON返回响应。 在撰写本文时,该API不需要密钥,并且具有相当自由的非商业许可,但有一些限制,因此非常适合我们的应用程序。

    如果您以前从未处理过API,请不要担心。 我们将使用Jribbble jQuery插件来帮助通过ID请求拍摄,并使用我们已经设计好的自定义布局将其插入DOM。 正如我已经提到的,我们将通过Jribbble插件和Dribbble API请求单独拍摄(出于该项目的目的,我们将从Envato Dribbble帐户拍摄6张照片)。

    正如您所期望的,Jribbble除了单独拍摄外,还允许您请求一系列参数,包括:

    • 试一下
    • 获得镜头的评论
    • 获得镜头的反弹
    • 通过列表名称获取拍摄列表
    • 获取球员的射门清单
    • 获取玩家正在追踪的镜头列表
    • 获取玩家喜欢的镜头列表
    • 获取玩家的个人资料详细信息
    • 获取玩家的关注者
    • 获取玩家关注的玩家
    • 获取球员的选秀

    我今天不会花任何时间详细讨论插件或API,但是如果您想扩展本教程的范围并探讨Jribbble的某些可能性,建议您阅读文档以了解更多信息。学到更多。 现在,转到实验室并下载Jribbble ,并将其保存到名为“ js”的新根目录中。


    步骤12:链接脚本

    要使Jribbble正常运行,我们需要做的第一件事就是连接相关的脚本。 该插件依赖jQuery,因此要使我们的插件正常工作,我们需要:

    • jQuery的最新发行版,
    • Jribbble代码,
    • 一个名为js / jribbble.shots.js的文件,它将是调用Dribbble镜头所需的所有功能的宿主。

    在HTML文件的底部,在

标记之间,添加以下代码:



步骤13:试一试

Jribbble'Get a Shot'参数的基本结构非常简单:

$.jribbble.getShotById(shotId, callback)

从Dribbble插入一个镜头ID,插件将捕获以下数据:

  • 镜头本身(400像素x 300像素)
  • 镜头标题
  • 玩家;选手
  • 观看次数
  • 注释
  • 喜欢
  • 篮板

让我们看一下Jribbble页面上使用的演示函数,以了解如何请求此信息并将其插入DOM:

$(document).ready(function () {		
		
	// API Ref: http://api.dribbble/shots/:id
	$.jribbble.getShotById(196071, function (shot) {
		var html = [];
		
		$('#shotById a:first').attr('href', shot.url);
		$('#shotById img').attr('src', shot.image_url);
		$('#shotById h3').text(shot.title);
		$('#shotById h4').html('by ' + 
			shot.player.name + '');
		
		html.push('
  • Views: ' + shot.views_count + '
  • '); html.push('
  • Likes: ' + shot.likes_count + '
  • '); html.push('
  • Comments: ' + shot.comments_count + '
  • '); html.push('
  • Rebounds: ' + shot.rebounds_count + '
  • '); $('#shotById ul').html(html.join('')); }); });

    即使您不是jQuery向导,这也应该相当简单。 插件将要查找的是ID为"shotById"的元素,然后将带有以下标记的镜头,视图,喜欢,注释等插入DOM:

    Shot Title

    Player URL

    • Views
    • Likes
    • Comments
    • Rebounds

    显然,这对于先前步骤中已经创建的现有HTML标记不起作用(原样)。 为了确保我们的辛勤工作不会被破坏,我们需要蚕食我们的标记,并对js / jribbble.shots.js文件中的基本代码进行一些更改。


    步骤14:摇一摇标记

    我建议的第一件事是采用我们已经创建的现有内容项标记,将其复制并注释掉,以确保我们为以下步骤提供参考。 接下来,使用以下代码覆盖未注释HTML:

    
    
        

      如您所见,我们确实缩减了索引文件中的标记。 下一步,我们将使jQuery填补空白。


      步骤15:创建一个新函数

      要进行射击并在

      元素中填充一些数据,我们需要在新创建的js / jribbble.shots / js文件中创建一个新函数。 我们的新功能如下所示:

      $(document).ready(function () {	
      
      $.jribbble.getShotById(332826, function (shot) {
          var html = [];
      
          $('#shot1 a:first').attr('href', shot.url);
          $('#shot1 img').attr('src', shot.image_url);
          
          html.push('
    • '); html.push('
    • '); html.push('
    • '); $('#shot1 ul').html(html.join('')); }); });

      毫无疑问,您的旧标记看起来非常熟悉这部分代码。 现在,只要准备好文档,该函数将执行以下步骤:

      • 从Dribbble拍摄ID为'332826'的照片
      • 查找ID为“ Shot1”的元素
      • 从Dribbble填充包含镜头URL的链接
      • 将图像位置放入子
        • 创建三个
        • 元素
        • 插入相关的元素以创建图标并计算数字。

        这里的好消息是,因为我们在整个项目中都小心使用了类名,所以不需要对CSS进行任何更改。 至此,我们使用ID为332826的Envato Dribbble镜头完成了我们的第一个特色内容项目。


        步骤16:填补空白

        到目前为止,尽管我们已经为另外五个特色内容项创建了一些占位符标记,但我们仅与一个特色内容项进行了合作。 现在是时候填补空白,并使这个设计看起来像一个正确的界面! 这个过程非常简单。 只需从最后一步复制特色内容项,然后将其复制五次,即可更改每个ID。 index.html文件的这一部分如下所示:

                  接下来,我们需要为每个特色内容项创建功能。 在您的js / jribbble.shots.js文件中,根据需要从最后一步复制功能,更改每个镜头的镜头ID和元素ID。 我们的最终脚本如下:

                  $(document).ready(function () {	
                  
                  $.jribbble.getShotById(332826, function (shot) {
                      var html = [];
                  
                      $('#shot1 a:first').attr('href', shot.url);
                      $('#shot1 img').attr('src', shot.image_url);
                      
                      html.push('
                • '); html.push('
                • '); html.push('
                • '); $('#shot1 ul').html(html.join('')); }); $.jribbble.getShotById(315548, function (shot) { var html = []; $('#shot2 a:first').attr('href', shot.url); $('#shot2 img').attr('src', shot.image_url); html.push('
                • '); html.push('
                • '); html.push('
                • '); $('#shot2 ul').html(html.join('')); }); $.jribbble.getShotById(247707, function (shot) { var html = []; $('#shot3 a:first').attr('href', shot.url); $('#shot3 img').attr('src', shot.image_url); html.push('
                • '); html.push('
                • '); html.push('
                • '); $('#shot3 ul').html(html.join('')); }); $.jribbble.getShotById(201434, function (shot) { var html = []; $('#shot4 a:first').attr('href', shot.url); $('#shot4 img').attr('src', shot.image_url); html.push('
                • '); html.push('
                • '); html.push('
                • '); $('#shot4 ul').html(html.join('')); }); $.jribbble.getShotById(70447, function (shot) { var html = []; $('#shot5 a:first').attr('href', shot.url); $('#shot5 img').attr('src', shot.image_url); html.push('
                • '); html.push('
                • '); html.push('
                • '); $('#shot5 ul').html(html.join('')); }); $.jribbble.getShotById(722560, function (shot) { var html = []; $('#shot6 a:first').attr('href', shot.url); $('#shot6 img').attr('src', shot.image_url); html.push('
                • ' + shot.views_count + '
                • '); html.push('
                • ' + shot.likes_count + '
                • '); html.push('
                • ' + shot.comments_count + '
                • '); $('#shot6 ul').html(html.join('')); }); });

                  快速说明一下,如果您真正专注于将HTTP请求减少到最低限度,则可以轻松地将每个函数包含在HTML的

                  你可能感兴趣的:(web页面uri唤醒应用_带有数据URI的高性能Web设计)