2013-02-28 56 views
3

這是我的例子:http://jsfiddle.net/rtCP3/62/間距相等div的容器中的

我有3個(或更多!)div的我希望空間在一個容器平分。在ng-repeat中使用角度時,樣式不會被拾取。當我硬編碼完全相同的元素時,它工作得很好。

角度輸出:

<div class="container ng-scope" ng-controller="ParentCtrl"> 
    <!-- ngRepeat: item in list --> 
    <div class="box ng-scope ng-binding" data-ng-repeat="item in list">item1</div> 
    <div class="box ng-scope ng-binding" data-ng-repeat="item in list">item2</div> 
    <div class="box ng-scope ng-binding" data-ng-repeat="item in list">item3</div> 
    <div class="box ng-scope ng-binding" data-ng-repeat="item in list">item4</div> 
    <span class="stretch"></span> 
</div> 

硬編碼:

<div class="container"> 
    <div class="box">Item 1</div> 
    <div class="box">Item 2</div> 
    <div class="box">Item 3</div> 
    <div class="box">Item 4</div> 
    <span class="stretch"></span> 
</div> 

我此基礎上這個計算器的問題:Fluid width with equally spaced DIVs

+0

通過刪除文本對齊CSS,我能夠將這些框放在一起(沒有任何其他明顯的問題)。 – 2013-02-28 16:38:41

+0

這不是我想要的,但請參閱其他stackoverflow問題的鏈接。 – 2013-02-28 16:51:33

回答

3

這工作。我不知道爲什麼,但它的空間是相同的:

<div class="container" ng-controller="ParentCtrl"> 
    <span data-ng-repeat="item in list"> 
     <div class="box">{{ item.name }}</div> 
    </span> 
    <span class="stretch"></span> 
</div> 

也許別人可以解釋爲什麼這樣的作品,但在你的提琴重複跨度元素框類上,但裏面提出兩種實現看相同。

+1

+1。我不明白爲什麼這會起作用/爲什麼它沒有開始工作,但它解決了這個問題。 – 2013-02-28 16:49:41

+0

這並沒有解決問題:http://jsfiddle.net/rtCP3/63/ – 2013-02-28 16:51:03

+0

馬修,以及刪除您的文字理由CSS。然後它的工作原理:http://jsfiddle.net/wagedomain/wtWV6/ – 2013-02-28 16:51:42

1

在SO問你引用一個評論說

我花了3h的發現,你應該在HTML中,每框之間的空間。 '證明'擴展了元素之間的空間,如果你的內容是<div/><div/><div/>它不起作用。你需要有<div/> <div/> <div/>

我相信ng-repeat不會在它的輸出之間放置任何空格,所以所有的div都相互對立,造成問題。

你可以創建自己的ng-repeat-like指令來添加一個空格。

+0

哇......我從來沒有想過要看那個。在我對dom的檢查中,我剛剛以正確的順序看到了它們。我將在未來繼續這個想法。 – 2013-02-28 19:11:52