《DOM编程艺术》二、javascript图片库


title: 《DOM编程艺术》二、javascript图片库
date: 2017-06-03 10:00:29
tags: DOM编程艺术


从这一篇开始会逐步完成一个图片库的案例,但我们不能直接把所有的图片直接放到一个页面里,因为图片下载的时间较长,用户需要等待很长时间去加载一个网页,所以我们需要一个图片库,把整个图片库的浏览链接集中安排在主页里,只在用户点击了这个主页里的某个图片链接时才把相应的图片加载。

1、建立基础的HTML结构

<!DOCTYPE html>
<html lang = "en">
<head>
    <meta charset = "utf-8"/>
    <title>Image Gallery</title>
</head>
<body>
    <h1>Snapshots</h1>
    <ul>
        <li>
            <a href = "images/fireworks.jpg" title = "A fireworks display">Fireworks</a>
        </li>
        <li>
            <a href = "images/coffee.jpg" title = "A cup of black offee">Coffee</a>
        </li>
        <li>
            <a href = "images/rose.jpg" title = "A red,red rose">Rose</a>
        </li>
        <li>
            <a href = "images/bigen.jpg" title = "The famous clock">Big Ben</a>
        </li>        
    </ul>
</body>
</html>
image

2、改进图片库

这个网页现在的功能是:

  1. 清单列表中的每个链接分别指向不同的图片,点击跳转到相应的图片页面。

  2. 从图片返回列表要借助于浏览器的back功能。

需要改进的地方:

  1. 点击某个链接时,能留在这网页而不是转到另一个窗口。

  2. 点击某个链接时,能在这个网页上同时看到那张图片及原有清单列表。

  3. 点击某个链接时,在图片的下方显示改图片的描述文字。

完成上述目标要完成的几项改进:

  1. 通过增加一个占位图片的办法在这个主页上为图片预留一个浏览区域。

  2. 点击某个链接时,拦截这个网页的默认行为。把占位图片替换为与那个链接相对应的图片。

  3. 点击某个链接时,获取链接的描述文字,保存到图片下方的位置。

第一步、增加占位图片

html部分

<img id = "placeholder" src = "images/placeholder.jpg" alt = "my image galley"/>

js部分

function showPic(whichpic){
    var source = whichpic.getAttribute("href");
    var placeholder = document.getElementById("placeholder");
    placeholder.setAttribute("src",source);
}

为了把占位图片替换为要查看的图片,需要一个方法来改变它的src属性。
参数whichpic代表一个指向某个图片的a元素,变量source是参数a元素的href属性值,变量placeholder是占位图片的元素对象。

我们还有另一种方法,也就是非DOM方法,直接用placeholder.src = source;,效果等同于placeholder.setAttribute("src",source);,我选择DOM方法的原因是setAttribute是第1级DOM,它的兼容性和可移植性更好,DOM本身适用于任何一种标记语言,DOM是一种适用于多种环境和多种程序设计语言的通用型API,而非DOM方法只能适用于web浏览器,所以在以后的选择时,尽量选择DOM方法。

最后将该方法单独存为一个叫做show_pic.js的文件并引用。在实际开发中,可以将多个功能放到一个js文件中,这样可以减少对站点的请求次数,提高性能。

<script src="script/script.js"></script>

第二步、事件处理函数

事件处理函数的作用是在特定事件发生时,调用特定的javascript代码。这个案例中要使用的是onclick点击事件。

 <a href = "images/fireworks.jpg" onclick = "showPic(this);return false;" title = "A fireworks display">Fireworks</a>

在每一条链接上增加onlcick事件和处理程序。showPic就是之前写好的方法,将this作为参数传进去,this这里指的就是a元素对象。

return false的作用是阻止默认行为被调用,a元素的默认行为是打开一个新窗口,我不需要这个效果,所以要组织。

事件处理函数的工作机制:在给某个元素添加了事件处理函数后,一旦事件发生,javascript代码便会执行,这些被调用的javascript代码可以返回一个值,这个值将被传递给事件处理函数,具体到此案例中,当onclick被触发时,如果执行的代码返回true,onclick事件处理函数就会认为这个链接被点击了,如果返回false,onclick事件处理函数就认为这个链接没有被点击,所以当onclick认为没有点击链接,自然也不会打开一个新链接。

第三步、增加图片描述文字

现在我要用DOM给图片增加一段描述,这段描述的位置在img标签之后,同时也起到了占位符的作用

<p id="description">Choose an image</p>

为了实现这个功能也需要扩展一下showPic函数。

  1. 获取a标签的title属性值,并存入变量text。

  2. 获取描述文本的元素,id值为description的p元素,保存到变量description。

  3. 把description对象的第一个子节点的nodeValue属性值设置为变量text的值。

function showPic(whichpic){
  var source = whichpic.getAttribute("href");
  var placeholder = document.getElementById("placeholder");
  placeholder.setAttribute("src",source);
  var text = whichpic.getAttribute('title');    // 1
  var description = document.getElementById('description');     // 2
  description.firstChild.nodeValue = text;      // 3
}

这里设置描述文本我使用的是nodeChild属性,nodeChild属性可以设置和获取文本元素的文本内容。需要注意的是必须是文本节点。

比如description是一个元素节点,那么description.nodeChild获取的就是null,用description的子节点才有效description.firstChild.nodeChild,这里description只有一个子节点并且是文本节点,所以使用firstChild和lastChild都一样,如果description有好几个子元素,要获取其中的某个可以用children[index]来获取。

最终效果

最后我们增加一些css样式来美化一下页面,创建style.css文件并引入html文件中。

body {
  font-family: "Helvetica","Arial",serif;
  color: #333;
  background-color: #ccc;
  margin: 1em 10%;
}

h1 {
  color: #333;
  background-color: transparent; 
}

a {
  color: #c60;
  background-color: transparent;
  font-weight: bold;
  text-decoration: none;
}

ul {
  padding: 0;
}

li {
  float: left;
  padding: 1em;
  list-style: none;
}

img {
  display: block;
  clear:both;
}

以下是script.js文件的最终内容

function showPic(whichpic){
  var source = whichpic.getAttribute("href");
  var placeholder = document.getElementById("placeholder");
  placeholder.setAttribute("src",source);
  var text = whichpic.getAttribute('title');
  var description = document.getElementById('description');
  description.firstChild.nodeValue = text;
}

html文件的最终结构如下

<!DOCTYPE html>
<html lang = "en">
<head>
    <meta charset = "utf-8"/>
    <title>Image Gallery</title>
    <link rel="stylesheet" type="" href="./css/style.css">
</head>
<body>
    <h1>Snapshots</h1>
    <ul>
        <li>
            <a href = "images/fireworks.jpg" onclick = "showPic(this);return false;" title = "A fireworks display">Fireworks</a>
        </li>
        <li>
            <a href = "images/coffee.jpg" onclick = "showPic(this);return false;" title = "A cup of black offee">Coffee</a>
        </li>
        <li>
            <a href = "images/rose.jpg"  onclick = "showPic(this);return false;" title = "A red,red rose">Rose</a>
        </li>
        <li>
            <a href = "images/bigben.jpg" onclick = "showPic(this);return false;"  title = "The famous clock">Big Ben</a>
        </li>        
    </ul>
    <img id = "placeholder" src = "images/placeholder.gif" alt = "my image galley"/>

    <p id="description">Choose an image</p>

    <script src="script/script.js"></script>
</body>
</html>

页面的最终效果如下,点击i链接可以改变图片和描述文字。


image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容