- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我在某种程度上理解使用 AngularJS 展开和折叠 div 背后的复杂想法,但并非全部。所以我知道如何在 ng-repeat 中展开/折叠多个对象及其值等。我遇到的问题是,如果我已经在 ng-repeat 中展开了一个项目,然后单击展开另一个项目,我希望当前展开的那个在新展开时自动折叠。另外,我应该能够毫无问题地单击同一项目上的展开/折叠。我碰壁了,我试图重新思考我在做什么。我的实际工作是通过折叠和展开来工作,我唯一无法得到的就是当我展开另一个项目时,一个项目会折叠起来。
例如,从我在下面提供的从头代码开始:
VA <- 将展开/折叠(展开时两个城市显示具有展开/折叠的能力)
(关于 VA 的扩展)
Virginia Beach
Richmond <- I expand Richmond then
现在我想扩大弗吉尼亚海滩,一旦我这样做,里士满就会崩溃,弗吉尼亚海滩就会扩大
同样的想法将适用于各州,一旦我扩大 TX,VA 就必须崩溃。
这就是我需要帮助理解的内容。
概念理念:
<div class="" ng-repeat="place in data">
<h4 class="">{{place.state}}</h4>
<button class="btn" ng-click="{{place.state}}.expanded=!{{place.state}}.expanded)">
<span ng-class="{'glyphicon glyphicon-minus': {{place.state}}.expanded, 'glyphicon glyphicon-plus': !{{place.state}}.expanded }"></span>
</button>
<div class="" ng-hide="{{place.state}}.expanded">
<table class="">
<thead>
<tr class="">
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{place.value}}</td>
</tr>
</tbody>
</table>
</div>
<div class="" ng-repeat="city in data.city">
<h4 class="">{{city.cName}}</h4>
<button class="btn" ng-click="city.expanded=!city.expanded)">
<span ng-class="{'glyphicon glyphicon-minus': city.expanded, 'glyphicon glyphicon-plus': !city.expanded }"></span>
</button>
<div class="" ng-hide="city.expanded">
<table class="">
<thead>
<tr class="">
<th>Population</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{city.pop}}</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
测试数据JSON:
$scope.data = [{
"state": "VA",
"value": '14',
"city": [{
"cName": 'Virginia Beach',
"pop": '650,000'
}, {
"cName": 'Richmond',
"pop": '850,000'
}]
}, {
"state": "TX",
"value": '31',
"city": [{
"cName": 'Austin',
"pop": '990,000'
}, {
"cName": 'Houston',
"pop": '1,450,000'
}]
}];
最佳答案
好吧,首先要做的事情是:当使用 ng-click、ng-show 或任何 ng-attribute 时,您不使用 {{}} - 这些值将自动正确解释。
所以你不想写
ng-click="{{place.state}}.expanded=!{{place.state}}.expanded)"
而是(最后多了一个“)”
ng-click="place.state.expanded= !place.state.expanded"
另外 - 你使用了一个很棒的 ng-repeat - 但是 - 在你的 ng-click 中你尝试在字符串上设置属性......这是行不通的。相反,您应该将属性设置为“place”
ng-click="place.expanded= !place.expanded"
这些更改将为您提供展开/折叠行为。为了实现您想要的目标,我建议您添加一个管理折叠/展开行为的函数。基本思想是您“记住”它们展开的内容 - 这样您就可以“折叠”之前展开的元素。或者,您也可以迭代 JSON 数据对象并将所有值重置为折叠(如果您有大量数据,您可能不应该这样做。
这是一个快速的 Plunker,可以完成您想要的任务:https://plnkr.co/edit/NRInXUJvMZh3ah588WyY?p=preview
基本思想是有两个范围变量,一个用于扩展的州,一个用于扩展的城市。如果用户单击一个州,则展开的州会折叠,单击的州会展开......对于城市来说也是如此。
关于javascript - AngularJS Collapse Expanded ng-在另一个展开上重复项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41643283/
如何在代码中展开/折叠WPF扩展器?我需要这样做才能在其中初始化控件。 最佳答案 使用IsExpanded属性,将其设置为true以使内容可见: myExpander.IsExpanded = tru
Powershell 展开让我发疯。 我有以下代码可以从交换收件人处检索电子邮件地址。我使用 ArrayList 是因为当您希望能够从数组中删除项目时,很多人都建议使用它。 $aliases = Ne
是否可以展开/折叠数据表中的子表?我的子表包含与其上方行相关的信息,我想显示/隐藏图像的点击。只是想知道我会怎么做? 这是我目前使用的:
我正在尝试创建一个可扩展的文本区域,仅当该框为空时,该区域才会折叠回其原始高度。如果它不为空,那么我希望文本区域保持扩展并根据需要增长(即,当用户输入更多文本时增长)。文本区域永远不应该隐藏输入的文本
当尝试将 nestedSortable jQuery 插件与其网站上提供的示例一起使用时,该插件无法正常工作。 拖放可以工作,但是当我需要折叠/展开时就会出现问题。我使用了另一个问题中建议的解决方案,
我有一个显示嵌套数据的表。数据如下所示: Objective 1 Objective 1.1 Objective 1.1.1 Objective 1.2
我正在使用 jQuery 从屏幕左侧展开/缩回菜单栏。 这是我到目前为止所拥有的: $(document).ready(function(){ $('.menu-button').on("clic
如何根据类别向页面上的图像添加隐藏/显示(折叠/展开)功能? 我希望具有特定类的图像在加载时折叠,并在 JS 中定义一些任意标记(比方说, Show ),然后在扩展中具有不同的任意标记( Hide )
我需要在折叠和展开后触发事件调整大小。当我尝试使用 SWT.Collapse 和 SWT.Expand 执行此操作时,树上没有任何更改,因为它在发生之前就已触发。有什么办法吗? 最佳答案 尝试调用 D
我有一个如下所示的域: package object tryme { type ALL = AlarmMessage :+: PassMessage :+: HeyMessage :+: CNil
我有一个扩展器列表,我想用全局切换按钮控制其展开状态(IsExpanded),该按钮应该在展开/折叠状态之间切换。 到目前为止,我得到的解决方案是通过将扩展器的 IsExpanded 状态绑定(bin
我试图根据 QWidget 是否展开/折叠来自动调整其大小。我尝试了几种发布的方法here和 here . 我没有设法采用这些,以便它按照我想要的方式工作:我希望 QWidget 在展开时调整自身大小
我正在尝试显示对象模型(机器人)列表,这些模型有一个可以是另一个机器人的字段 Parent。 我已经使用 Django 的 MPTT 实现了一个嵌套列表: {% load mptt_tags %}
鉴于下表/代码,我想添加两项。我不太了解 JavaScript,这段代码是另一个程序员留下的。该代码在所有其他方面都按预期工作。 这是两个项目: 表格应该以折叠状态开始。所有节点都应该是崩溃到“祖 p
我想要一张可以展开或折叠的表格。我的要求是当我点击表格行然后隐藏行显示或者当我点击其他表格行然后上一个打开的行隐藏或显示相对隐藏行。我发现一个 jquery jxpand 非常适合我,它显示隐藏的行但
如果当您向下滚动页面时元素展开或折叠,页面会突然重置并且焦点会移动到页面顶部。 有什么方法可以防止页面移动或使其不那么突然? $(document).ready(function () {
我正在使用以下代码来扩展特定的线性布局,并且遵循了本教程 http://gmariotti.blogspot.sg/2013/09/expand-and-collapse-animation.html
当垂直偏移超过特定阈值时,如何使android中的可折叠工具栏自动折叠/展开? 例如,如果垂直偏移超过 getScrollRange() 的半点,则可折叠工具栏应自动展开,低于该阈值时应折叠。 最佳答
http://t-webdesign.co.uk/new/ 如何在不使用固定高度属性的情况下让灰色 div (#content_right) 扩展到与左侧 div 相同的大小? 谢谢 最佳答案 你可能
设置一个简单的 WordPress 博客,仅包含一个页面,即博客存档。但我遇到了一个问题,我想要切换摘录和内容显示更多/显示更少的功能,以便访问者可以轻松浏览同一页面上的帖子,而无需页面重新加载或被发
我是一名优秀的程序员,十分优秀!