如何在不使用 HTML 框架的情况下做到这一点?

How to do this without using HTML Frames?

我有这样的需求:

我想到了使用框架来实现这一点。但是正如有人向 avoid using 框架建议的那样,我无法找到如何去做的方法。 是否可以在不使用单个页面内的框架和逻辑的情况下实现这一点?

您可以使用 Ajax,为了方便使用 Ajax,使用 jquery 库:

<script src="http://code.jquery.com/jquery-1.4.min.js" type="text/javascript"></script>
<script type="text/javascript">
        $(document).ready(function(){
           $("#topic1").click(function(){
            $('#result').load('topic1.html');
           }); 

           $("#topic2").click(function(){
            $('#result').load('topic2.html');
           });
         });
    </script>
<ul>
    <li><a id="topic1" href="#">Topic 1</a></li>
    <li><a id="topic2" href="#">Topic 2</a></li>
    <li><a id="topic3" href="#">Topic 3</a></li>
</ul>
<div id="result" style="clear:both;">
</div>

您可以通过声明一个对象 {link1: page1, link2: page2} 然后 foreach 它并为每个道具编写点击函数来改进此代码。

这只是一个演示解决方案。您可以根据自己的需要创建自己的,只是给您一个想法。

JSFiddle : DEMO

$(".topic2, .topic3").fadeOut();
$(".topic1").fadeIn();
$(".row").click(function(){
 var curId = this.id;
    $(".topic1, .topic2, .topic3").fadeOut();
 $("." + curId).fadeIn();
});
.main
{
    display:inline-block;
    width:20%;
    float:left;
    background:#333;
    height:auto;
    margin:0px;
    padding:px;
    color:#eee;
    text-align:center;
}

.row
{
    display:block;
    width:100%;
    height:25px;
    margin:0px;
    padding:10px 0px;
    border-bottom:1px solid black;
    cursor:pointer;
}
.row:hover
{
background:#1C1B1F;
}    

.sub-topics
{
    display:inline-block;
    position:absolute;
    margin: 0px 15px;
    width:65%;
    height:95%;
    overflow:hidden;
}

.topic1, .topic2, .topic3
{
    display:inline-block;
    position:absolute;
    width:100%;
    min-height:100%;
    background:#eee;
    color:black;
    overflow:hidden;
    padding:5px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<div class="main">
    <div class="row" id="topic1">
        Topic 1
    </div>
    <div class="row" id="topic2">
        Topic 2
    </div>
    <div class="row" id="topic3">
        Topic 3
    </div>
</div>
<span class="sub-topics">
<div class="topic1">
<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</p> 
</div>
<div class="topic2">
<p>TOPIC 2 ..... Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</p> 
</div>
<div class="topic3">
<p>TOPIC 3 ..... Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</p> 
</div>
</span>