我最近开始重组一个网站,目前使用的是框架和框架集。
我现在采用了典型的 structure.html :
<body>
<div>
<div id="headerNavigation"></div>
<div id="PageContent"></div>
<div id="footer"></div>
</div>
</body>
</html>
使用以下jQuery脚本填充DIV:
<head>
<script>
$.get('PageHeader.html', processHeader, "html").fail(function() { alert("There is a problem loading the header. Please re-try"); });
function processHeader(file_data)
{
$("#headerNavigation").html(file_data);
}
$.get('TermsConditions.html', processContent, "html").fail(function() { alert("There is a problem loading a resource. Please re-try"); });
function processContent(file_data)
{
$("#PageContent").html(file_data);
}
$.get('Footer.html', processFooter, "html").fail(function() { alert("There is a problem loading a resource. Please re-try"); });
function processFooter(file_data)
{
$("#Footer").html(file_data);
}
</script>
</head>
当我指定Content页面时,这很有用,但是,我需要某种jQuery函数,当我点击导航菜单中的项目时,它会使用正确的内容转发/填充DIV - index.html :
<html>
<head>
<!-- jQuery code for drop down nav menus -->
<script type="text/javascript">
$(document).ready(function(){
$('nav li ul').hide().removeClass('fallback');
$('nav li').hover(
function () {
$('ul', this).stop().slideDown(300);
},
function () {
$('ul', this).stop().slideUp(300);
}
);
});
</script>
</head>
<body>
<nav class="site-nav">
<ul class="menu-nav wrap menu menu--hor">
<li class="data-sources"><a href="#" title="">Date Sources <span class="icon-caret-down"></span> </a>
<li>
<a href="frameset.html?Information.html">Information</a>
<ul class="fallback">
<li><a href="frameset.html?ovens.html">Ovens</a></li>
<li><a href="frameset.html?fridges.html">Fridges</a></li>
<li><a href="frameset.html?tables.html">Tables</a></li>
<li><a href="frameset.html?costing.html">Costing</a></li>
<li><a href="frameset.html?install.html">Installation</a></li>
</ul>
</li>
<li>
<a href="frameset.html?legal.html">Legal Info</a>
<ul class="fallback">
<li><a href="frameset.html?terms.html">Terms & Conditions</a></li>
<li><a href="frameset.html?data.html">Data Protection</a></li>
</ul>
</li>
<li>
<a href="frameset.html?contact/html">Contact Us</a>
<ul class="fallback">
<li><a href="javascript:openHelpWind('contact')">Contact Details</a></li>
<li><a href="frameset.html?comments.html">Your Comments</a></li>
<li><a href="frameset.html?addinfos.html">Additional Info</a></li>
</ul>
</li>
<li>
<a href="#">Need Help?</a>
<ul class="fallback">
<li><a href="javascript:parent.PageHeader.openHelpWind(helpContext)">Need Help</a></li>
<li><a href="externalsite">FAQs</a></li>
<li><a href="externalsite">Ask our Experts</a></li>
</ul>
</li>
<li>
<a href="frameset.html?cookies.html">Cookies</a>
</li>
</li>
</ul>
</nav>
</body>
</html>
我将非常感谢如何创建一个函数来实现这一目标。
由于
更新21-06-2013 基本网站框架:
的index.html
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width">
<script src="javascript/modernizr-2.6.2.min.js"></script>
<title>Welcome</title>
<link id="productStyle" type="text/css" href="css/style.css" rel="stylesheet">
<script type="text/javascript" src="javascript/jquery-1.9.1.min.js"></script>
<script type="text/javascript" src="javascript/jquery-ui-1.10.1.custom.min.js"></script>
<!-- JavaScript functions to enable dropdown navigation-->
<script type="text/javascript">
$(document).ready(function(){
$('nav li ul').hide().removeClass('fallback');
$('nav li').hover(
function () {
$('ul', this).stop().slideDown(300);
},
function () {
$('ul', this).stop().slideUp(300);
}
);
});
</script>
<script type="text/javascript">
function gofor(a) {
$.get(a, processContent, 'html').fail(function() { alert('There is a problem loading a resource. Please re-try');});
}
function processContent(file_data)
{
$("#PageContent").html(file_data);
}
</script>
</head>
<body>
<!-- MENU START -->
<nav class="site-nav">
<ul class="menu-nav ">
<li class="menu--home"><a href="index.html " title="home"><span class="icon-home"></span></a></li>
<li>
<a href="frameset.html?Information.html">Information</a>
<ul class="fallback">
<li><a onclick="gofor('information.html')">Information (go for)</a></li>
<li><a onclick="gofor('openaccount.html')"> New Customer (Go For)</a>
<li><a onClick="gofor('information.html')">Information Go For onClick</a></li>
<li><a href="javascript:gofor('information.html')">Information Go For HREF</a></li>
<li><a href="frameset.html?ovens.html">Ovens</a></li>
<li><a href="frameset.html?fridges.html">Fridges</a></li>
<li><a href="frameset.html?tables.html">Tables</a></li>
<li><a href="frameset.html?costing.html">Costing</a></li>
<li><a href="frameset.html?install.html">Installation</a></li>
</ul>
</li>
<li>
<a href="frameset.html?legal.html">Legal Info</a>
<ul class="fallback">
<li><a href="frameset.html?terms.html">Terms & Conditions</a></li>
<li><a href="frameset.html?data.html">Data Protection</a></li>
</ul>
</li>
<li>
<a href="#">Contact Us</a>
<ul class="fallback">
<li><a href="javascript:openHelpWind('contact')">Contact Details</a></li>
<li><a href="frameset.html?comments.html">Your Comments</a></li>
<li><a href="frameset.html?addingds.html">Adding Directors Searches</a></li>
</ul>
</li>
</li>
</ul> <!-- END menu-nav -->
</nav> <!-- END nav.site-nav -->
<!-- MENU END -->
<section>
<div class="page-heading">
<h1 class="wrap">Welcome to Tables, Ladders and Chairs </h1>
</div>
<div>
Other welcome content
</div>
</section>
<footer class="site-footer" role="contentinfo">
<div class="wrap">
<small>2013 TL&C’s. </small>
</div>
</footer>
Frameset.html:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN">
<html lang="en">
<head>
<script type="text/javascript" src="javascript/jquery-1.9.1.min.js"></script>
<script>
$.get('PageHeader.html', processHeader, "html").fail(function() { alert("There is a problem loading a resource. Please re-try"); });
function processHeader (file_data)
{
$("#header").html(file_data);
}
</script>
</head>
<body>
<div>
<div id="header"></div>
<div id="PageContent"></div>
<div id="footer"></div>
</div>
</body>
</html>
</body>
</html>
PageHeader.html:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<script src="javascript/modernizr-2.6.2.min.js"></script>
<title>Page Header</title>
<link id="productStyle" type="text/css" href="css/style.css" rel="stylesheet">
<script type="text/javascript" src="javascript/jquery-1.9.1.min.js"></script>
<script type="text/javascript" src="javascript/jquery-ui-1.10.1.custom.min.js"></script>
<!-- JavaScript functions to enable dropdown navigation-->
<script type="text/javascript">
$(document).ready(function() {
$('nav li ul').hide().removeClass('fallback');
$('nav li').hover(
function () {
$('ul', this).stop().slideDown(300);
},
function () {
$('ul', this).stop().slideUp(300);
}
);
});
</script>
<script type="text/javascript">
function gofor(a) {
$.get(a, processContent, 'html').fail(function() { alert('There is a problem loading a resource. Please re-try');});
}
function processContent(file_data)
{
$("#PageContent").html(file_data);
}
</script>
<!-- MENU START -->
<nav class="site-nav">
<ul class="menu-nav ">
<li class="menu--home"><a href="index.html " title="home"><span class="icon-home"></span></a></li>
<li>
<a href="frameset.html?Information.html">Information</a>
<ul class="fallback">
<li><a onclick="gofor('information.html')">Information (go for)</a></li>
<li><a onclick="gofor('openaccount.html')"> New Customer (Go For)</a>
<li><a href="frameset.html?ovens.html">Ovens</a></li>
<li><a href="frameset.html?fridges.html">Fridges</a></li>
<li><a href="frameset.html?tables.html">Tables</a></li>
<li><a href="frameset.html?costing.html">Costing</a></li>
<li><a href="frameset.html?install.html">Installation</a></li>
</ul>
</li>
<li>
<a href="frameset.html?legal.html">Legal Info</a>
<ul class="fallback">
<li><a href="frameset.html?terms.html">Terms & Conditions</a></li>
<li><a href="frameset.html?data.html">Data Protection</a></li>
</ul>
</li>
<li>
<a href="#">Contact Us</a>
<ul class="fallback">
<li><a href="javascript:openHelpWind('contact')">Contact Details</a></li>
<li><a href="frameset.html?comments.html">Your Comments</a></li>
<li><a href="frameset.html?addingds.html">Adding Directors Searches</a></li>
</ul>
</li>
</li>
</ul> <!-- END menu-nav -->
</nav> <!-- END nav.site-nav -->
<!-- MENU END -->
Information.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html lang="en">
<head>
<title>Information</title>
<link type="text/css" rel="stylesheet" href="css/style.css">
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
</head>
<body>
<form>
Information about Tables Ladders and Chairs etc.
</form>
<br>
</body>
</html>
由于
答案 0 :(得分:1)
您可以为菜单中的每个链接添加对此函数的调用:
<a onclick="$.get('Information.html', processContent, 'html')" >Information</a>
如您所见,您将重复使用第一次加载内容的相同功能:
$.get('Information.html', processContent, 'html')
通过这种方式,您刚刚调用了相同的'processContent',但是要加载不同的页面。您可以通过添加第三个函数来简化onclick事件,该函数将由onclick(或href)调用,然后将调用该函数来加载内容,如下所示:
<a onclick="gofor('Information.html')">Information</a>
或者这个:
<a href="javascript:gofor('Information.html')">Information</a>
然后添加这个简单的函数:
function gofor(page){
$.get(page, processContent, 'html').fail(function() { alert('There is a problem loading a resource. Please re-try');});
}
显然你不能使用这个功能来加载外部内容,因为它被浏览器禁止
您的索引页面应该是这样的,请注意id为“pageContent”的div,其中将加载页面以及您需要在页面中加载内容所需的功能。
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://modernizr.com/i/js/modernizr.com-custom-2.6.1-01.js"></script>
<title>Welcome</title>
<link id="productStyle" type="text/css" href="css/style.css" rel="stylesheet">
<!-- JavaScript functions to enable dropdown navigation-->
<script type="text/javascript">
$(document).ready(function(){
$('nav li ul').hide().removeClass('fallback');
$('nav li').hover(
function () {
$('ul', this).stop().slideDown(300);
},
function () {
$('ul', this).stop().slideUp(300);
}
);
});
</script>
<script type="text/javascript">
function gofor(a) {
$.get(a, processContent, 'html').fail(function() { alert('There is a problem loading a resource. Please re-try');});
}
function processContent(file_data)
{
$("#PageContent").html(file_data);
}
</script>
</head>
<body>
<!-- MENU START -->
<nav class="site-nav">
<ul class="menu-nav ">
<li class="menu--home"><a href="javascript:gofor('index.html')" title="home"><span class="icon-home"></span></a></li>
<li>
<a href="javascript:gofor('Information.html')">Information</a>
<ul class="fallback">
<li><a href="javascript:gofor('information.html')">Information (go for)</a></li>
<li><a href="gofor('openaccount.html')"> New Customer (Go For)</a>
<li><a href="javascript:gofor('ovens.html')">Ovens</a></li>
<li><a href="javascript:gofor('fridges.html')">Fridges</a></li>
<li><a href="javascript:gofor('tables.html')">Tables</a></li>
<li><a href="javascript:gofor('costing.html')">Costing</a></li>
<li><a href="javascript:gofor('install.html')">Installation</a></li>
</ul>
</li>
<li>
<a href="javascript:gofor('legal.html')">Legal Info</a>
<ul class="fallback">
<li><a href="javascript:gofor('terms.html')">Terms & Conditions</a></li>
<li><a href="javascript:gofor('data.html')">Data Protection</a></li>
</ul>
</li>
<li>
<a href="#">Contact Us</a>
<ul class="fallback">
<li><a href="javascript:openHelpWind('contact')">Contact Details</a></li>
<li><a href="javascript:gofor('comments.html')">Your Comments</a></li>
<li><a href="javascript:gofor('addingds.html')">Adding Directors Searches</a></li>
</ul>
</li>
</li>
</ul> <!-- END menu-nav -->
</nav> <!-- END nav.site-nav -->
<!-- MENU END -->
<section>
<div class="page-heading">
<h1 class="wrap">Welcome to Tables, Ladders and Chairs </h1>
</div>
<div>
Other welcome content
</div>
<div id="PageContent">
</div>
<footer class="site-footer" role="contentinfo">
<div class="wrap">
<small>2013 TL&C’s. </small>
</div>
</footer>
答案 1 :(得分:0)
您无需通过javascript加载所有这些元素。事实上,我认为这是不好的做法。您正在进行不必要的通话,这会导致访问者的加载时间更长。标准做法是加载您的初始内容,然后根据需要使用javascript来响应用户命令。
我理解你要将内容分成单独的部分(页眉,页脚等等),但这通常不是这样做的。有一些模板引擎可以完成你想要实现的功能而无需额外的ajax调用来引入常规的html内容。以下是分离可重用内容的一些基本示例:
PHP(服务器端):
<?php include 'pageheader.html'; ?>
<div>My main content</div>
<?php include 'footer.html'; ?>
Handlebars.js(客户端)
{{>pageheader}}
<div>My main content</div>
{{>footer}}
话虽如此,如果你绝对必须坚持使用当前的设置,那么你只需要从a标签中解析出url并将其发送到你的processContent函数。以下是如何使用jquery执行此操作的示例:
$('li').on('click', function (e) {
var url = $(this).find(">:first-child").attr('href');
$.get(url, processContent, "html").fail(function() { alert("There is a problem loading a resource. Please re-try"); });
});
上面的代码基本上只绑定每个li的click事件,并在将该值传递给processContent函数之前获取标记的href值