使用javascript实现图片库的基本功能案例详解(附代码)

要使用js实现图片库的基本功能:当点击某个链接时,能留在这个页面查看图片,而不是转到另一个窗口。当点击某个链接时,能在这个页面同时看到那张图片以及原有的图片清单。apache php mysql

图片库html:

  1. nbsp;html>        <span class="typ">Image</span><span class="pln"> </span><span class="typ">Gallery</span>        

    Avengers

        

登录后复制                    AAAAR1                            AAAAR2                            AAAAR3                            AAAAR4                使用javascript实现图片库的基本功能案例详解(附代码)    

Choose an image.

    

css渲染文件:

  1. body {font-family: "Helvetica", "Arial", serif;color: #333;background-color: #ccc;margin: 1em 10%;}h1 {color:#333;background-color: transparent;}a {color:#60;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;}

登录后复制

拟定解决方法:

通过一个占位符图片的方法在这个主页上为图片预留一个浏览区域。

在点击某个链接时,拦截这个网页的默认行为。

立即学习“Java免费学习笔记(深入)”;

在点击某个链接时,把占位符图片替换为与那个链接相对应的图片。

先选择一张图片做为占位符:

  1. 使用javascript实现图片库的基本功能案例详解(附代码)

登录后复制

要想替换占位符图片为想要查看的图片,需要改变它的src属性。js中的setAttribute函数可以做到这一点。可以利用这一特性来编写一个js函数来解决问题。

  1. function showPic(whichpic)

登录后复制

这个函数仅接受一个图片链接参数,用来转换图片。whichpic作为一个元素节点,可以使用getAttribute函数来得到它的href属性:

  1. var source = whichpic.getAttribute("href");

登录后复制

然后获取占位符图片:

  1. var placeholder = document.getElemntById("placeholder");

登录后复制

得到占位符图片对象后,就可以对占位图对象进行属性设置,即替换相应的图片。

  1. placeholder.setAttribute("src", source);

登录后复制

完整的函数:

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

登录后复制

接下来就要将这个js函数和标记文档结合起来。

事件处理函数:事件处理函数的作用是:在特定事件发生时调用特定的js代码。

这里想要在用户点击某个链接的时候触发一个动作,所以需要使用onclick事件处理函数。

showPic函数需要一个参数:一个带有href属性的元素节点参数。这里可以使用this关键字,this关键字指代的是当前的标签元素。

同样的,我还想在链接被点击时不会跳到另一个窗口,因此需要阻断掉链接被点击时的默认行为,只进行js函数触发的替换图片行为。

这里可以给js函数添加一个返回值false,这样onclick函数就会认为这个链接没有被点击,从而不会打开一个新窗口。

具体代码:

  1. AAAAR1

登录后复制

这里的this关键字就是指代的这个元素节点。

这样就完成了图片库需求的功能。

对这个函数进行扩展:

我还想在点击页面的时候切换图片的描述。图片库文档里每个图片都有一个title属性,同样的思路:

  1. var text = whichpic.getAttribute("title");

登录后复制

先得到title属性,再进行替换。

childNodes属性:可以用来获取任何一个元素的所有子元素。

假设需要将body元素中的所有子元素提取出来:查看body有多少个子元素。

  1. var body_element = document.getElementsByTagName = ("body")[0];alert(body_element.childNodes.length);

登录后复制

[0]表示取得的是数组中第一个(也是唯一一个)body元素。

由childNodes属性返回的数组包含所有类型的节点,而不仅仅是元素节点,事实上文档中几乎每一样东西都是一个节点。所以返回的值很大。

nodeType属性:使用nodeType属性来找到相应的节点。不过nodeType的返回值并不是英文:

元素节点返回1;

属性节点返回2;

文本节点返回3;

  1. alert(body_element.nodeType);

登录后复制

通过这条语句来查看节点。

回到要增加的功能:首先跟图片一样,要增加一个文字描述的占位符,设置id属性

  1. Choose an image.

登录后复制

将其放置在图片的下方,接下来就要让图片的title替换这个文本内容:

  1. var text = whichpic.getAttribute("title");var description = document.getElementById("description");

登录后复制

nodeValue属性:想要改变一个文本节点的值,就要使用DOM方法的nodeValue属性。

此例中,包含在p元素中的文本节点是

元素的第一个子节点,因此,需要得到的是第一个子节点的nodeValue属性值。

  1. alert(description.childNodes[0].nodeValue);

登录后复制

firstChild和lastChild值

childNodes[0]可以使用firstChild来替换,最后一个子节点用lastChild来表示。

最后,使用nodeValue来刷新文本:

完整代码:

  1. 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;}

登录后复制

将text的值传给

元素的文本节点,目标达成。

页面效果:

使用javascript实现图片库的基本功能案例详解(附代码)

使用javascript实现图片库的基本功能案例详解(附代码)

相关文章:

JavaScript图片本地预览功能的实现方法

JavaScript模仿Pinterest实现图片预加载功能

相关视频:

使用JavaScript-李炎恢Javascript视频教程

以上就是使用javascript实现图片库的基本功能案例详解(附代码)的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
编程技术

用javascript写一个表单验证案例详解(代码全)

2025-3-8 3:39:17

编程技术

瞬间懂了,浅析对JS中的盒模型认识与理解

2025-3-8 3:39:25

0 条回复 A文章作者 M管理员
欢迎您,新朋友,感谢参与互动!
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
私信列表
搜索