本文通过获取首页内容来讲解Web页面拖拽获取当前页数据,功能类似在google查看图片,这里面涉及如下五个步骤:

(1)页面首次加载时读取第一页数据

(2)触发滚动条拖拽动作

(3)Ajax异步读取下一页数据

(4)服务端把数据封装为Json返回

(5)把页面数据通过DOM元素绘制在页面上

接下来就按这五个步骤依次进行


1、页面首次加载时会加载main.js文件。在此文件中增加CURRENT_ITEM_INDEX变量,用于标识当前话题的索引值;增加方法getPageContent(),用于页面加载时调用,获取第一页数据。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/**
 
* 按时间降序排列后标识页面最后一条记录的索引值
 
*/
var 
CURRENT_ITEM_INDEX = 0;
 
$(document).ready(
function
()
{
    
// 获取首页内容
    
getPageContent(CURRENT_ITEM_INDEX);
});
 
function 
getPageContent(currentIndex)
{
    
var 
data = {
"currentIndex"
: currentIndex};
    
asyncRequest(
"mainContent.data"
, data, 
function
(result)
    
{
        
// 由第3步实现
    
});
}

2、触发滚动条拖拽动作。在main.js加载时对window绑定scroll事件

1
2
3
4
5
6
7
$(document).ready(
function
()
{
    
// 略
    
getBreifUserInfo();
    
// 监听滚动条拖拽事件
    
bindScrollEvent();
});


【备注】:由于涉及到不断地下拉滚动条,所以需要增加一个标识isQueryFlag,若正在查找数据时则不再响应下拉事件

/**

 * 是否正在查询数据标识

 */

var isQueryFlag = false;


3、Ajax异步读取下一页数据。实现bindScrollEvent()方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/**
 
* 绑定滚动条拖拽事件
 
*/
function 
bindScrollEvent()
{
    
var 
scrollBarDistance = 0; 
// 滚动条的当前位置
    
var 
documentHeight = 0; 
// 文档高度
    
var 
windowHeight = $(window).height(); 
// 当前窗口高度
    
$(window).scroll(
function
(){
        
scrollBarDistance = $(document).scrollTop();
        
documentHeight = $(document).height();
        
if
(scrollBarDistance + windowHeight >= documentHeight)
        
{
            
if
(isQueryFlag === 
true
)
            
{
                
return
;
            
}
 
            
// 获取页面内容
            
getPageContent(CURRENT_ITEM_INDEX);
        
}
    
});
}

4、服务端把数据封装为Json返回

(1)修改配置文件system-data.xml,把拖拽动作方法与服务端读取数据的业务处理逻辑关联起来

1
2
<!--获取系统首页内容信息-->
<
business 
name
=
"mainContent" 
business-class
=
"com.medical.server.data.MainDataAction" 
/>

(2)定义服务端读取数据的业务处理类com.medical.server.data.MainDataAction

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
@Override
public 
String execute() 
throws 
FrameException
{
    
// 获取当前记录索引值
    
String currentIndex = getParameter(
"currentIndex"
);
    
if 
(FrameUtil.isEmpty(currentIndex))
    
{
        
TopicResultBean result = 
new 
TopicResultBean();
        
result.setErrorCode(FrameErrorCode.REQUEST_PARAM_ERROR);
        
return 
gson.toJson(result);
    
}
     
    
// 从数据库中读取数据
    
int 
index = Integer.valueOf(currentIndex);
    
List<TopicDAO> topicList = TopicUtil.getTopicList(index);
    
if 
(FrameUtil.isEmpty(topicList))
    
{
        
TopicResultBean result = 
new 
TopicResultBean();
        
result.setErrorCode(FrameErrorCode.REQUEST_CONTENT_EMPTY);
        
return 
gson.toJson(result);
    
}
     
    
// 组装界面所需要内容
    
List<TopicBean> topicBeanList = 
new 
ArrayList<TopicBean>();
    
for 
(TopicDAO element : topicList)
    
{
        
UserDAO author = UserUtil.getUserByName(element.getUserId());
         
        
TopicBean bean = 
new 
TopicBean();
        
bean.setUserName(author.getUserId());
        
bean.setUserIcon(author.getIconPath());
        
bean.setNickName(author.getUserSign());
         
        
bean.setTopicId(element.getTopicId());
        
bean.setTopicTitle(element.getTopicTitle());
        
bean.setCommentNum(CommentUtil.getCommentNum(element.getTopicId()));
        
bean.setTopicSummary(getTopicSummary(element.getPrescript()));
        
bean.setTopicTime(element.getTopicTime());
         
        
topicBeanList.add(bean);
    
}
    
// 返回JSON结果
    
TopicResultBean result = 
new 
TopicResultBean();
    
result.setErrorCode(
0
);
    
result.setTopicList(topicBeanList);
    
return 
gson.toJson(result);
}


【备注】:为了使内容简洁,中间省略了一些处理函数


5、把页面数据通过DOM元素绘制在页面上

(1)异步读取数据,并对数据合法性进行判断

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// 设置查询标识
isQueryFlag = 
true
;
 
asyncRequest(
"mainContent.data"
, data, 
function
(result)
{
    
// 若读取数据未成功直接返回
    
var 
resultJson = eval(result);
    
if
(resultJson.errorCode != 0)
    
{
        
return
;
    
}
    
var 
topicList = resultJson.topicList;
    
if
(!topicList){
        
return
;
    
}
     
    
// 重置数据当前索引值
    
CURRENT_ITEM_INDEX = CURRENT_ITEM_INDEX + topicList.length;
     
    
// 操纵DOM把数据绘制到页面上
    
$.each(topicList, 
function
(i, item){
        
appendData(i, item);
    
});
     
    
// 重置查询标识
    
isQueryFlag = 
false
;
});


(2)DOM元素绘制的实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/**
 
* 操纵DOM把数据绘制到页面上
 
*/
function 
appendData(i, item)
{
    
var 
topicItem = $(
"<div />"
).attr(
"class"
"main_item"
);
    
topicItem.appendTo($(
"#main_content_dynamic_id"
));
    
// 添加用户头像      
    
var 
userIcon = $(
"<i />"
).attr(
"class"
"main_item_icon"
);
    
userIcon.appendTo(topicItem);
    
// 添加挑战内容
    
var 
content = $(
"<div />"
).attr(
"class"
"main_item_content"
);
    
content.appendTo(topicItem);
 
    
// >>>>>>设置挑战话题标题 
    
var 
topWrapper = $(
"<div />"
).attr(
"class"
"main_item_wrapper"
);
    
var 
topicTitle = $(
"<div />"
).attr(
"class"
"main_item_title"
);
    
var 
titleLink = $(
"<a />"
).attr(
"href"
"#"
).text(item.topicTitle);
    
titleLink.appendTo(topicTitle);
    
topicTitle.appendTo(topWrapper);
    
topWrapper.appendTo(content);
 
    
// >>>>>>设置挑战话题标题
    
var 
topicTime = $(
"<div />"
).attr(
"class"
"main_item_time"
).text(item.topicTime);
    
topicTime.appendTo(topWrapper);
 
    
// >>>>>>设置用户名称和昵称
    
var 
centerWrapper = $(
"<div />"
).attr(
"class"
"main_item_wrapper"
);
    
var 
userName = $(
"<label />"
).attr(
"class"
"main_item_author"
).text(item.userName + 
","
);
    
var 
userNick = $(
"<label />"
).attr(
"class"
"main_item_nickname"
).text(item.nickName);
    
userName.appendTo(centerWrapper);
    
userNick.appendTo(centerWrapper);
    
centerWrapper.appendTo(content);
 
    
// >>>>>>设置话题摘要信息
    
var 
middleWrapper = $(
"<div />"
).attr(
"class"
"main_item_wrapper"
);
    
var 
topicSummary = $(
"<div />"
).attr(
"class"
"main_item_substance"
).html(item.topicSummary);
    
topicSummary.appendTo(middleWrapper);
    
middleWrapper.appendTo(content);
 
    
// >>>>>>设置话题附属信息
    
var 
bottomWrapper = $(
"<div />"
).attr(
"class"
"main_item_wrapper"
);
    
var 
topicAttach = $(
"<div />"
).attr(
"class"
"main_item_attach"
);
    
topicAttach.appendTo(bottomWrapper);
    
bottomWrapper.appendTo(content);
 
    
// >>>>>>>>>>>>设置话题关注信息
    
var 
followLink = $(
"<a />"
).attr(
"href"
"#"
);
    
var 
followIcon = $(
"<i />"
).attr(
"class"
"main_item_attention"
);
    
followIcon.appendTo(followLink);
    
followLink.appendTo(topicAttach);
    
followLink.text(
"关注"
);
 
    
// >>>>>>>>>>>>设置话题关注信息
    
var 
commentLink = $(
"<a />"
).attr(
"href"
"#"
);
    
var 
commentIcon = $(
"<i />"
).attr(
"class"
"main_item_discuss"
);
    
commentIcon.appendTo(commentLink);
    
commentLink.appendTo(topicAttach);
    
commentLink.text(item.commentNum + 
"人评论"
);
 
    
// >>>>>>>>>>>>设置话题分享信息
    
var 
shareLink = $(
"<a />"
).attr(
"href"
"#"
);
    
var 
shareIcon = $(
"<i />"
).attr(
"class"
"main_item_share"
);
    
shareIcon.appendTo(shareLink);
    
shareLink.appendTo(topicAttach);
    
shareLink.text(
"分享"
);
 
    
// >>>>>>>>>>>>设置话题收藏信息
    
var 
favoriteLink = $(
"<a />"
).attr(
"href"
"#"
);
    
var 
favoriteIcon = $(
"<i />"
).attr(
"class"
"main_item_collection"
);
    
favoriteIcon.appendTo(favoriteLink);
    
favoriteLink.appendTo(topicAttach);
    
favoriteLink.text(
"收藏"
);
}

6、效果演示

(1)向数据表topictable中增加两条记录

(2)在浏览器输入http://localhost:8080/medical,效果如下:


【备注】:

1、可以多插入些记录,就可以观察拖拽效果了 

2、这里的拖拽事件没有考虑窗口的缩小与放大情况

3、为了简洁起见,没有增加返回顶端功能