Ngx-Bootstrap-정렬 가능
ngx-bootstrap 정렬 가능 구성 요소는 드래그 드롭 지원과 함께 구성 가능한 정렬 가능 구성 요소를 제공합니다.
SortableComponent
선택자
bs-sortable
입력
fieldName − 문자열, 입력 배열이 객체로 구성된 경우 필드 이름.
itemActiveClass − 문자열, 활성 항목의 클래스 이름.
itemActiveStyle− {[키 : 문자열] : 문자열; }, 활성 항목의 스타일 개체입니다.
itemClass − 문자열, 항목의 클래스 이름
itemStyle − 문자열, 항목의 클래스 이름
itemTemplate− TemplateRef <any>, 사용자 지정 항목 템플릿을 지정하는 데 사용됩니다. 템플릿 변수 : 항목 및 색인;
placeholderClass − 문자열, 자리 표시 자의 클래스 이름
placeholderItem − 컬렉션이 비어있는 경우 표시 될 문자열, 자리 표시 자 항목
placeholderStyle − 문자열, 자리 표시자를위한 스타일 객체
wrapperClass − 문자열, 항목 래퍼의 클래스 이름
wrapperStyle− {[키 : 문자열] : 문자열; }, 항목 래퍼에 대한 스타일 개체
출력
onChange− ngModelChange와 동일하게 배열 변경 (재정렬, 삽입, 제거)시 발생합니다. 새 항목 컬렉션을 페이로드로 반환합니다.
예
정렬 가능을 사용할 것이므로 ngx-bootstrap 등급 장에서 사용 되는 app.module.ts를 사용하도록 업데이트 해야합니다.SortableModule 과 DraggableItemService.
SortableModule 및 DraggableItemService를 사용하도록 app.module.ts를 업데이트합니다.
app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { AppComponent } from './app.component';
import { TestComponent } from './test/test.component';
import { AccordionModule } from 'ngx-bootstrap/accordion';
import { AlertModule,AlertConfig } from 'ngx-bootstrap/alert';
import { ButtonsModule } from 'ngx-bootstrap/buttons';
import { FormsModule } from '@angular/forms';
import { CarouselModule } from 'ngx-bootstrap/carousel';
import { CollapseModule } from 'ngx-bootstrap/collapse';
import { BsDatepickerModule, BsDatepickerConfig } from 'ngx-bootstrap/datepicker';
import { BsDropdownModule,BsDropdownConfig } from 'ngx-bootstrap/dropdown';
import { PaginationModule,PaginationConfig } from 'ngx-bootstrap/pagination';
import { PopoverModule, PopoverConfig } from 'ngx-bootstrap/popover';
import { ProgressbarModule,ProgressbarConfig } from 'ngx-bootstrap/progressbar';
import { RatingModule, RatingConfig } from 'ngx-bootstrap/rating';
import { SortableModule, DraggableItemService } from 'ngx-bootstrap/sortable';
@NgModule({
declarations: [
AppComponent,
TestComponent
],
imports: [
BrowserAnimationsModule,
BrowserModule,
AccordionModule,
AlertModule,
ButtonsModule,
FormsModule,
CarouselModule,
CollapseModule,
BsDatepickerModule.forRoot(),
BsDropdownModule,
ModalModule,
PaginationModule,
PopoverModule,
ProgressbarModule,
RatingModule,
SortableModule
],
providers: [AlertConfig,
BsDatepickerConfig,
BsDropdownConfig,
BsModalService,
PaginationConfig,
ProgressbarConfig,
RatingConfig,
DraggableItemService],
bootstrap: [AppComponent]
})
export class AppModule { }
정렬 가능한 구성 요소에 스타일을 사용하도록 styles.css를 업데이트하십시오.
Styles.css
.sortableItem {
padding: 6px 12px;
margin-bottom: 4px;
font-size: 14px;
line-height: 1.4em;
text-align: center;
cursor: grab;
border: 1px solid transparent;
border-radius: 4px;
border-color: #adadad;
}
.sortableItemActive {
background-color: #e6e6e6;
box-shadow: inset 0 3px 5px rgba(0,0,0,.125);
}
.sortableWrapper {
min-height: 150px;
}
정렬 가능한 구성 요소를 사용하려면 test.component.html을 업데이트하십시오.
test.component.html
<bs-sortable
[(ngModel)]="items"
fieldName="name"
itemClass="sortableItem"
itemActiveClass="sortableItemActive"
wrapperClass="sortableWrapper">
</bs-sortable>
해당 변수 및 메소드에 대한 test.component.ts를 업데이트하십시오.
test.component.ts
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-test',
templateUrl: './test.component.html',
styleUrls: ['./test.component.css']
})
export class TestComponent implements OnInit {
items = [
{
id: 1,
name: 'Apple'
},
{
id: 2,
name: 'Orange'
},
{
id: 3,
name: 'Mango'
}
];
constructor() {}
ngOnInit(): void {
}
}
구축 및 봉사
다음 명령을 실행하여 각도 서버를 시작하십시오.
ng serve
일단 서버가 가동되고 실행됩니다. http : // localhost : 4200을 엽니 다.