0

这是我通过 ajax 加载某个页面的脚本。

$(function(){

      // Keep a mapping of url-to-container for caching purposes.
      var cache = {
        // If url is '' (no fragment), display this div's content.
        '': $('.bbq-default')
      };

      // Bind an event to window.onhashchange that, when the history state changes,
      // gets the url from the hash and displays either our cached content or fetches
      // new content to be displayed.
      $(window).bind( 'hashchange', function(e) {

        // Get the hash (fragment) as a string, with any leading # removed. Note that
        // in jQuery 1.4, you should use e.fragment instead of $.param.fragment().
        var url = $.param.fragment();

        // Remove .bbq-current class from any previously "current" link(s).
        $( 'a.bbq-current' ).removeClass( 'bbq-current' );

        // Hide any visible ajax content.
        $( '.bbq-content' ).children( ':visible' ).hide();

        // Add .bbq-current class to "current" nav link(s), only if url isn't empty.
        url && $( 'a[href="#' + url + '"]' ).addClass( 'bbq-current' );

        if ( cache[ url ] ) {
          // Since the element is already in the cache, it doesn't need to be
          // created, so instead of creating it again, let's just show it!
          cache[ url ].show();
        } else {
          // Show "loading" content while AJAX content loads.
          $( '.bbq-loading' ).show();

          // Create container for this url's content and store a reference to it in
          // the cache.

          cache[ url ] = $( '<div class="bbq-item"/>' )


            // Append the content container to the parent container.
            .appendTo( '.bbq-content' )


            // Load external content via AJAX. Note that in order to keep this
            // example streamlined, only the content in .infobox is shown. You'll
            // want to change this based on your needs.
            .load( url, function(){
              // Content loaded, hide "loading" content.
              $( '.bbq-loading' ).hide();
            });
        }
      })
      // Since the event is only triggered when the hash changes, we need to trigger
      // the event now, to handle the hash the page may have loaded with.
      $(window).trigger( 'hashchange' );
    });

我正在使用 JQuery BBQ 插件,现在我的问题是如何获得我想要加载的页面的唯一 div?不是整个页面本身,知道怎么做吗?

4

1 回答 1

7

load()方法允许在实际文件 url 之后添加选择器,以仅加载与选择器匹配的内容。

例如:

$('#someDiv').load('myFile.php #contentDiv');/* note space before selector*/

这将检索完整输出,myFile.php但仅从contentDiv该输出插入somediv

如果选择器是一个包含多个项目的类,它将全部检索它们

API 参考:http ://api.jquery.com/load/

请参阅标题为的部分Load Fragments

于 2012-12-24T00:47:04.103 回答