【问题标题】:clone and append in jquery mobile- doubling up?在jquery mobile中克隆和追加-加倍?
【发布时间】:2011-10-22 18:03:55
【问题描述】:

当我在 jquery mobile 中克隆和附加/前置 html 片段时,片段会加倍。您可以插入此代码并进行测试。

<!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="width=device-width, initial-scale=1"> 

    <!-- standard Jquery/jQuery Mobile Libraries -->
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.0b2/jquery.mobile-1.0b2.min.css" />
    <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.2.min.js"></script>
    <script type="text/javascript" src="http://code.jquery.com/mobile/1.0b2/jquery.mobile-1.0b2.min.js"></script>   
    </head> 

    <body>  
    <div data-role="page" id="mainmenu">
    <div data-role="header" data-position="inline"></div>

    <div class="ui-body ui-body-c">
        <div data-role="content">   

        <a href="#" class="preShowHTML">click to view HTML</a>      
        <pre>
        <span id="HTMLOut">
        my HTML output goes here...
        </span>
        </pre>
    </div>
    </div>  


    <div id='groupA' class='preGroups'>         
        <div id='placeholder' ></div>   
    </div>

    <fieldset class="ui-grid-a" data-inline="true">     
        <div class="ui-block-b"><button type="submit"  class="addPart" data-theme="a" data-icon="plus">Add Serial/Part</button></div>
    </fieldset>

    <div id='template'>                 
        <div data-role="fieldcontain">
            <input type="range" name="QTY" id="preQuant01" value="1" min="1" max="10"/>
        </div>

    </div>
</div>

<style>
#template,  #HTMLOut, #XMLOut{
    display:none;
}
</style>


<script>
counter = 1;

$(document).ready(function() {

/* Add a listeners to Add Part */   
    $('.addPart').click(function() {    
            myClone = $('#template').clone();           
            myClone.attr("id", "template-" + counter);  
            counter++;
            myClone.appendTo("#placeholder").trigger( "create" );
            // myClone.appendTo("#placeholder").page(); does not work in this version?

        return false;
    });   

    // Toggle Show/Hide HTML
    $('.preShowHTML').click(function() {    
         $("#HTMLOut").text($("body").html());
         $("#HTMLOut").toggle();
        return false;
    });             
});
</script>

【问题讨论】:

    标签: jquery-mobile append clone


    【解决方案1】:

    我认为柜台放错地方了。但是,这并没有使该示例更具功能性。

    myClone = $('#template').clone();           
    myClone.attr("id", "template-" + counter);  
    //counter++;
    myClone.appendTo("#placeholder");
    $('#template-'+counter).page();                
    counter++;
    

    我不确定这是正确的方法 - 在 jquery mobile 应用了它的侦听器和格式之后克隆 html。

    【讨论】:

      【解决方案2】:

      AJAX 可能会使它稍微干净一些,但这是一个开始:

      $(document).ready(function(){
          $("div").live("pageshow", function () { 
              counter = 0;
              $(".addPart").click(function() {    
                      counter++;
                      $("#placeholder").append('<div  id="template-'+counter+'"><div data-role="fieldcontain"><input type="range" name="slider" class="ui-slider-input ui-input-text ui-body-null ui-corner-all ui-shadow-inset ui-body-c" id="slider'+counter+'" value="0" min="0" max="100" /></div></div>');
                      $("#template-"+counter).trigger("create");
      
                  return false;
              });   
      
          });
      });
      </script>
      

      【讨论】:

      • 不完全...我在 page() 函数上找不到任何东西。它应该做什么?
      • JQM 标记页面的所有元素。加载 DOM 后,让 JQM 处理标记要容易得多,让其完成困难的部分。 “page()”函数让这一切变得简单......
      • 我还没有真正测试过该代码...回头看后我会做一些修改...页面加载后的jquery克隆正在创建具有正确标记的滑块和页面功能实际上是再次标记它。一个包含滑动 jquery 移动功能,而另一个只是样式看起来像一个,但实际上并没有做任何事情。
      猜你喜欢
      • 2016-07-01
      • 2018-02-11
      • 2015-08-08
      • 2017-06-30
      • 2018-04-24
      • 2011-10-10
      • 2014-11-16
      • 2013-05-11
      • 2013-09-22
      相关资源
      最近更新 更多