2

わかりました、これに対する答えを見たら、私はばかげていると感じます。私はそれを確信しています。

これは以前とまったく同じ方法で作成しましたが、現在、新しいバージョン用にコードをリファクタリングしています。jQuery Mobile で折りたたみ可能なセットを動的に作成しようとしていますが、html が正しく表示されません。

  <div data-role="header">
        <h2>Playground</h2>
    </div>
    <div data-role="content">
        <div data-role="button" id="addprimary" data-inline="true">Add 5</div>
        <div data-role="collapsible">             
            <h4>Collapsible</h4> 
            <form id="makecollapsible">
            </form>
        </div>
    </div>
    <div data-role="footer">
        <h4>Please, no applause</h4>
    </div>
</div>

<script>
$('#addprimary').on('click', function () {
    Markup.Collapsible();
});

var Markup = new Object();


Markup.Collapsible = function () {

$('#makecollapsible')
.append($('<div>')
    .attr({ 'data-role': 'collapsible-set', 'id': 'primary' })
 );
for (i = 0; i < 5; i++) {
    ($('<div>')
         .attr({ 'data-role': 'collapsible', 'data-content-theme': 'c', 
              'data-collapsed': 'true' })
         .html('<h4>' + i +'</h4>'))
    .appendTo('#primary');
   }
}
</script>

誰かがこのhttp://jsfiddle.net/c2jLY/を見て、私が間違っていることを教えてください。私<div>data-role='collapsible'は折りたたみ可能なものとしてレンダリングされません。これは、後で入れようとしている HTML にも影響を与えています。

助けていただければ幸いです、ありがとう!

4

2 に答える 2

5

関数内Markup.Collapsibleとその最後に、以下を追加します。collapsible -setの場合、 a を強化していることを jQM に伝え、.collapsibleset()それを と組み合わせる必要があります.trigger('create')

$('#makecollapsible').collapsibleset().trigger('create');

デモ


アイテムを動的に追加するときは、親要素で拡張メソッドを呼び出すことを忘れていました。そうすることで、子要素が強化されます。.collapsible().trigger('create')したがって、折りたたみ式を追加するたびに使用する必要はありません。

于 2013-09-20T21:49:32.897 に答える
0

私がここに示しているのは単純なものですが、機能しています:

<script type="text/javascript">
//dynamically make 10 collapsible items and append them to the collapsible-set
var jj = "SUPER item added..";

$('[data-role="content"]').append('<div id="set" data-role="collapsible-set"></div>');
var count;
	for (count=0; count < 10; count++) {  // div id should be from id='c0' to 'c9'
		$("#set").append('<div id="c' + count + '" data-role="collapsible">');
		$("#c" + count.toString()).append('<h3>Adding element_' + count +'</h3>');
		$("#c" + count.toString()).append(jj + 'count ' + count + '</div>');

	}

// either one is tested working below:
//		$('[data-role="content"]').trigger('create');
		$( "#set" ).collapsibleset( "refresh" );

</script>
<script src="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
<link href="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<body>
	<!------------------------page 1 ListView template-->
		<div data-role="page"  id="page01">
		<div data-role="header" data-theme="b" data-position="fixed">			
			<h2>-- DEMO -- &nbsp;&nbsp;</h2>
		</div>
		<div data-role="content"  id="content">
  
    </div>
</body>

于 2016-07-13T08:10:43.330 に答える