首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Angular 2 ngui-带*ngFor的可排序列表

Angular 2 ngui-带*ngFor的可排序列表
EN

Stack Overflow用户
提问于 2017-08-21 22:09:51
回答 2查看 588关注 0票数 1

我正在尝试创建一个动态的可排序列表,当它是静态的时,它工作得很好,但当我试图从基列表中获取它时,它就变得不可排序了

这是我的静态列表代码

代码语言:javascript
复制
<ul ngui-sortable>
    <li >Order</li>
    <li> Me</li>
    <li >Right</li>
    <li id="the">The</li>
    <li id="into">Into</li>
    <li id="put">Put</li>
</ul>

这就是我想要做的

代码语言:javascript
复制
<ul ngui-sortable  >
    <li *ngFor="let menu of menus">{{menu.title}}</li>
</ul>

请帮个忙

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-08-22 00:07:32

已通过ng2-dnd https://github.com/akserg/ng2-dnd修复这是我的代码

代码语言:javascript
复制
<div class="row">
    <div class="col-sm-3">
        <div class="panel panel-success">
            <div class="panel-heading">
                 Menus
            </div>
            <div class="panel-body">
                <ul class="list-group" dnd-sortable-container [sortableData]="menus">
                    <li style="color:blue;" *ngFor="let menu of menus; let i = index" class="list-group-item" dnd-sortable [sortableIndex]="i">{{menu.title}}</li>
                </ul>
            </div>
        </div>
    </div>
    <div class="col-sm-6">
        <div class="panel panel-default">
            <div class="panel-body">
                My prefences:<br/>
                <span *ngFor="let menu of menus; let i = index">{{i + 1}}) {{menu.title}}<br/></span>
            </div>
        </div>
    </div>
</div>

这是我的组件

代码语言:javascript
复制
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
import {GestionMenu} from "./gestionmenu";
import {GestionMenuService} from "./gestionmenu.service";
import {TreeModel} from "ng2-tree/index";
@Component({
    selector: 'order-menu',
    templateUrl: './order-menu.component.html',
    styleUrls: ['./order-menu.component.css']

})
export class OrderMenuComponent implements OnInit  {
    menus: GestionMenu[];
    menu: GestionMenu;

    constructor(
        private router: Router,
        private menuService: GestionMenuService) { }


    getMenus(): void {
        this.menuService.getMenus()
            .subscribe(
                menus => this.menus = menus, //Bind to view
                err => {
                    // Log errors if any
                    console.log(err);
                }
            );
    }

    ngOnInit(): void {
        this.getMenus();
    }
}

最后,这是我的模块

代码语言:javascript
复制
@NgModule({
    imports: [
        ...
        DndModule.forRoot()

    ],
    declarations: [
       ...
       OrderMenuComponent,


    ],

    providers: [
        GestionMenuService
    ]

})
export class GestionMenuModule { }
票数 0
EN

Stack Overflow用户

发布于 2017-08-21 23:06:32

angular *ngFor阻止你做这样的事情。只要不更新位于component.ts文件中的menus数组,*ngFor将以相同的顺序进行渲染。您需要在发布<li>项时触发一个事件,以便更新数组的顺序。

我建议您使用另一个库,如ng2-dnd。看看示例n°9,它似乎符合所需的行为。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45799231

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档