javascript ajax刷新图片,ajax无刷新实现图片切换特效_ajax教程

本文介绍了一个使用Ajax和JavaScript实现的图片轮播系统。代码中定义了一个AjaxMethod类,用于从数据库获取图片信息,通过AjaxPro.AjaxMethod特性进行异步调用。在HTML页面中,设置了图片的鼠标悬停事件,并在JavaScript中实现了图片的预加载、切换效果以及自动轮播功能。页面加载时,通过Ajax获取指定分类的图片列表并进行预加载。
摘要由CSDN通过智能技术生成

一、AjaxMethod

using System;

using System.Data;

using System.Data.SqlClient;

namespace AjaxImage

{

/**

/// AjaxMethod 的摘要说明。

///

public class AjaxMethod

{

public AjaxMethod()

{

}

public static string ConnectionString = System.Configuration.ConfigurationSettings.AppSettings[“ConnectionString”].ToString();

GetDataSet#region GetDataSet

public static DataSet GetDataSet(string sql)

{

SqlDataAdapter sda = new SqlDataAdapter(sql, ConnectionString);

DataSet ds = new DataSet();

sda.Fill(ds);

if (ds != null)

return ds;

else

return null;

}

#endregion

[AjaxPro.AjaxMethod]

public static DataSet GetPhotoList( int iCategoryID )

{

string sql = “Select id,photo_path FROM Photo where photo_category_id=” + iCategoryID ;

return GetDataSet( sql );

}

[AjaxPro.AjaxMethod]

public static DataSet GetPhotoInfo( int id )

{

string sql = string.Format(“SELECT photo_title, photo_description FROM Photo WHERE id = {0}”, id);

return GetDataSet( sql );

}

}//end class

}

二、页面HTML代码:

                space.gif%E2%80%9D

                play_bw.gif%E2%80%9D

                    οnmοuseοut=”this.src=images/play_bw.gif”> pause_bw.gif%E2%80%9D

                    οnmοuseοut=”this.src=images/pause_bw.gif”> prev_bw.gif%E2%80%9D

                    οnmοuseοut=”this.src=images/prev_bw.gif”> next_bw.gif%E2%80%9D

οnmοuseοut=”this.src=images/next_bw.gif”>

三、JAVASCRIPT:

// 定时器

var timeDelay;

// 图片自动浏览时的时间间隔

var timeInterval = 4000;

// Array对象,存储图片文件的路径

var image;

// 当前显示的图片序号

var num;

// 图片信息数据表

var dt;

// 预加载图片信息

function PreloadImage(iCategoryID)

{

// 采用同步调用的方式获取图片的信息

var ds = AjaxImage.AjaxMethod.GetPhotoList(iCategoryID).value;

// 如果返回了结果

if (ds)

{

// 判断数据表是否不为空

if (ds.Tables[0].Rows.length > 0)

{

// 返回的图片信息数据表

dt = ds.Tables[0];

// 用image对象存储图片的文件路径

image = new Array();

// 图片在Photos目录下

for (var i = 0; i < dt.Rows.length; i++)

{

image[i] = “Photos/” + dt.Rows[i].photo_path;

}

// imagePreload对象用于实现图片的预缓存

var imagePreload = new Array();

for (var i = 0;i < image.length;i++)

{

// 通过新建Image对象,并将其src属性指向图片的URL

// 显现图片的预缓存

imagePreload[i] = new Image();

imagePreload[i].src = image[i];

}

// 初始化一些变量

num = -1;

//nStatus = 0x09;

// 加载第一张图片

next_image();

}

else // 分类下没有图片

{

alert(“该目录下没有图片!”);

}

}

}

// 实现图片切换时的效果

function image_effects()

{

// Transition的值为0~23之间的随机数,代表24种切换效果

// 具体值与效果之间的对应见MSDN

document.slideShow.filters.revealTrans.Transition = Math.random() * 23;

// 应用并播放切换效果

document.slideShow.filters.revealTrans.apply();

document.slideShow.filters.revealTrans.play();

}

function next_image()

{

// 当前图片的序号向后移动,如果已经是最后一张,

// 则切换到第一张图片

num++;

num %= image.length;

// 图片的切换效果

image_effects();

                // 将对象的src属性设置为当前num对应的路径

// 切换图片的显示

document.slideShow.src = image[num];

}

function previous_image()

{

// 当前图片的序号向后移动,如果已经是最后一张,

// 则切换到第一张图片

num += image.length – 1;

num %= image.length;

// 图片的切换效果

image_effects();

                // 将对象的src属性设置为当前num对应的路径

// 切换图片的显示

document.slideShow.src = image[num];

}

function slideshow_automatic()

{

// 当前图片的序号向后移动,如果已经是最后一张,

// 则切换到第一张图片

num ++;

num %= image.length;

// 图片的切换效果

image_effects();

                // 将对象的src属性设置为当前num对应的路径

// 切换图片的显示

document.slideShow.src = image[num];

timeDelay = setTimeout( “slideshow_automatic()”,timeInterval );

}

// 停止自动播放

function pauseSlideShow()

{

// 清除定时器,不再执行slideshow_automatic函数

clearTimeout(timeDelay);

}

四、在主页面的ONLOAD事件里面添加:

οnlοad=”PreloadImage(2)”

五、WebConfig添加:

六、数据库脚本:

CREATE TABLE [Photo] (

[id] [int] IDENTITY (1, 1) NOT NULL ,

[photo_title] [varchar] (128) COLLATE Chinese_PRC_CI_AS NULL ,

[photo_description] [text] COLLATE Chinese_PRC_CI_AS NULL ,

[photo_category_id] [int] NULL ,

[photo_path] [varchar] (255) COLLATE Chinese_PRC_CI_AS NULL

) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

GO

http://www.cnblogs.com/wander/archive/2006/09/19/508648.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值