在视图中动态添加 jquery 选项卡

发布于 2024-12-15 18:57:00 字数 1549 浏览 2 评论 0原文

我对 MVC 和 jQuery 非常陌生,并且在向 jQuery 选项卡面板添加新选项卡时遇到问题。

我有一个 ASP.NET MVC3 视图,其中包含两个部分视图。第一个是搜索表单,第二个显示搜索结果。

现在我需要将搜索结果放入选项卡面板的选项卡中。在此项目的稍后阶段,它应该像这样工作:用户搜索一些关键字,并且对于每个新搜索,都会将一个新选项卡添加到选项卡面板中。这样用户应该可以切换到以前的搜索。但我还没有走到这一步。

我首先尝试的是向页面添加一个静态选项卡面板,其中包含一个包含搜索结果的选项卡。这相当简单,我没有遇到任何问题。接下来我尝试做的是,每次用户单击搜索表单的提交按钮时,都会向选项卡面板添加一个包含静态内容(“Hello World”)的新选项卡。但这实际上不起作用:

我可以看到新选项卡已添加到选项卡面板中。但仅限于< 1秒。搜索结果一呈现,新选项卡就会消失。渲染部分视图似乎会覆盖 jQuery/JavaScript 所做的更改。

这是视图(_SearchInput 是搜索表单的部分视图,_SearchResults 是用于显示搜索结果的部分视图):

<div class="roundedBorder"> 
    @Html.Partial("_SearchInput")
</div>

<div id="tabs" style="margin-top:7px;">

    <ul>
        <li><a href="#fragment-1" id="tab1Link">Test 1</a></li>
    </ul>

    <div id="contentcontainer">
        <div id="fragment-1">@Html.Partial("_SearchResults")</div>
    </div>
</div>

_SearchInput 中我在文档准备好时添加选项卡,并在单击表单的提交按钮时调用 searchClick

<script>
$(document).ready(function () {
  /* show tabs */
  $('#tabs').tabs();
});

function searchClick() {
    var keyword = $("#searchTextInput").val().trim();

    if (keyword == null || keyword == "") {
        return false;
    }

    var title = keyword.substring(0, 10);

    $('#contentcontainer').append("<div id='fragment-2'>hello world</div>");
    $('#tabs').tabs("add", "#fragment-2", title);
}
</script>

I am very new to MVC and jQuery and I have a problem adding a new tab to a jQuery tab panel.

I have a ASP.NET MVC3 View that contains two partial views. The first one is a search form and the second one displays the search results.

Now I need to put the search results in a tab of a tab panel. At a later point in this project it should work like this: The user searches for some keywords, and for each new search a new tab is added to the tab panel. This way it should be possible for the user to switch to a previous search. But I am not this far yet.

What I tried first was to add a static tab panel to the page with a single tab that contains the search results. This was rather easy and I had no problems. What I tried to do next, was to add a new tab with static content ("Hello World") to the tab panel each time the user clicks the submit button of the search form. But this doesn't really work:

I can see that the new tab is added to the tab panel. But only for < 1 sec. The new tab disappears as soon as the search results are rendered. It seems like rendering the partial view overwrites the changes made by jQuery/JavaScript.

This is the view (_SearchInput is the partial view for the search form, _SearchResults is the partial view used to display search results):

<div class="roundedBorder"> 
    @Html.Partial("_SearchInput")
</div>

<div id="tabs" style="margin-top:7px;">

    <ul>
        <li><a href="#fragment-1" id="tab1Link">Test 1</a></li>
    </ul>

    <div id="contentcontainer">
        <div id="fragment-1">@Html.Partial("_SearchResults")</div>
    </div>
</div>

In _SearchInput I add the tabs when the document is ready and call searchClick when the submit button of the form is clicked:

<script>
$(document).ready(function () {
  /* show tabs */
  $('#tabs').tabs();
});

function searchClick() {
    var keyword = $("#searchTextInput").val().trim();

    if (keyword == null || keyword == "") {
        return false;
    }

    var title = keyword.substring(0, 10);

    $('#contentcontainer').append("<div id='fragment-2'>hello world</div>");
    $('#tabs').tabs("add", "#fragment-2", title);
}
</script>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

给妤﹃绝世温柔 2024-12-22 18:57:00

您如何提交表格?如果您没有发布 ajaxy 类型的结果,这是正常的,因为您的页面将在表单提交时刷新。

不要提交表单,而是使用 jquery 提交表单,并在成功回调中执行发布表单提交任务。

例如:

$('form').submit(function(evt) {
    evt.preventDefault();

  $.ajax({  
  type: "POST",  
  url: "formsubmiturl",  
  data: dataposted,  
  success: function() {  
   // add jquery tab stuff here
  }  

});

How are you submitting the form? If your not posting an ajaxy type of result this would be expected as your page will be refreshing on form submit.

Rather, than submit the form, submit the form with jquery and in your success callback perform your post form submission tasks.

EG:

$('form').submit(function(evt) {
    evt.preventDefault();

  $.ajax({  
  type: "POST",  
  url: "formsubmiturl",  
  data: dataposted,  
  success: function() {  
   // add jquery tab stuff here
  }  

});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文