在单页面利用(SPA)的开辟中,页面的跳转平日须要处理得愈加优雅跟高效。jQuery UI 供给了一个名为 sref
的功能,可能便利地在单页面利用中实现页面之间的跳转。本文将具体介绍怎样利用 jQuery UI-sref 实现单页面利用的页面跳转。
在利用 jQuery UI-sref 之前,你须要确保以下前提曾经满意:
以下是一个利用 jQuery UI-sref 实现页面跳转的基本示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Single Page Application with jQuery UI-sref</title>
<link rel="stylesheet" href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>
</head>
<body>
<!-- 页面跳转链接 -->
<a href="#page2" data-rel="sref">Go to Page 2</a>
<!-- 页面内容 -->
<div id="page1" data-rel="sref">Page 1 Content</div>
<div id="page2" data-rel="sref" style="display:none;">Page 2 Content</div>
<script>
$(document).ready(function() {
// 初始化页面跳转功能
$(document).on('click', 'a[data-rel="sref"]', function(e) {
e.preventDefault();
var target = $(this).attr('href');
$('#container').load(target);
});
});
</script>
</body>
</html>
a
标签中的 data-rel="sref"
用于标识该链接为页面跳转链接。e.preventDefault()
方法禁止了链接的默许行动。$(this).attr('href')
获取目标页面的 URL。$('#container').load(target)
将目标内容加载到页面的 #container
容器中。你可能为页面跳转增加动画后果,使页面切换愈加腻滑。
$(document).on('click', 'a[data-rel="sref"]', function(e) {
e.preventDefault();
var target = $(this).attr('href');
$('#container').fadeOut('fast', function() {
$('#container').load(target).fadeIn('fast');
});
});
假如你须要在页面跳转时转达参数,可能在 URL 中附加查询字符串。
<a href="#page2?param1=value1¶m2=value2" data-rel="sref">Go to Page 2 with Parameters</a>
然后在目标页面中获取这些参数:
$(document).ready(function() {
var queryString = $(location).attr('search');
var params = {};
$.each(queryString.substr(1).split('&'), function(i, v) {
var pair = v.split('=');
params[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]);
});
console.log(params); // {param1: "value1", param2: "value2"}
});
jQuery UI-sref 是一个实现单页面利用页面跳转的便捷方法。经由过程公道利用,你可能轻松实现优雅的页面切换后果,同时还可能转达参数跟增加动画后果。盼望本文能帮助你更好地懂得跟利用 jQuery UI-sref。