이번에는 Element-UI 테이블을 사용하여 드래그 앤 드롭 기능을 구현하는 방법에 대해 소개하겠습니다. Element-UI 테이블을 사용하여 드래그 앤 드롭 기능을 구현하는 경우 다음은 실제 사례입니다. 봐.
Element-UI의 테이블 구성 요소는 매우 강력하지만 우리의 요구 사항은 훨씬 더 강력합니다...
간단하고 투박한 렌더링:
1. 데이터 기반
전통적인 드래그 효과는 모두 mousedown, mousemove, mouseup 이벤트
를 통해 dom 노드 수정 및 삭제를 기반으로 하지만 Vue는 데이터 기반 프런트엔드 프레임워크이므로 개발 중에 dom 운영을 피해야 합니다
그리고 Element의 Table 구성 요소 -UI는 캡슐화되어 있습니다. 매우 엄격하여 DOM을 직접 조작하면 예측할 수 없는 버그가 쉽게 발생할 수 있습니다.
그래서 내 핵심 아이디어는 다음과 같습니다. 테이블 헤더(열)를 배열을 통해 렌더링한 다음 배열 순서를 수정하여 열을 수정합니다. sorting of the list
템플릿 부분:
<p> <el-table> <slot></slot> <el-table-column> </el-table-column> </el-table> </p>
위 데이터는 목록 데이터 모음, 옵션은 Table 컴포넌트 구성 항목, header는 상위 컴포넌트에서 전달되는 테이블 헤더 데이터 모음
props: { data: { default: function () { return [] }, type: Array }, header: { default: function () { return [] }, type: Array }, option: { default: function () { return {} }, type: Object } }
구성 항목은 Element-UI
의 API에 따라 삭제될 수 있습니다.그러나 구성 요소 내부에서 사용되는 여러 매개 변수가 있습니다:
1.header-cell-class-name
은 다음과 같은 함수에 바인딩됩니다. 드래그하는 동안 점선 효과를 얻으려면 헤더 셀에 클래스를 동적으로 추가하세요.
2.column-key
는 헤더 배열의 인덱스에 바인딩되어 수정이 필요한 헤더 요소의 첨자를 결정하는 데 사용됩니다
3.render-header
테이블 헤더 렌더링 기능 , 사용자 정의를 추가하는 데 사용됨 mousemove 및 기타 관련 이벤트를 모니터링하는 방법
2. 드래그 상태 기록
드래그 프로세스 중에 몇 가지 주요 매개 변수를 기록해야 합니다.
data () { return { tableHeader: this.header, dragState: { start: -1, // 起始元素的 index end: -1, // 结束元素的 index move: -1, // 移动鼠标时所覆盖的元素 index dragging: false, // 是否正在拖动 direction: undefined // 拖动方向 } } }
또한 상위 요소는 헤더를 전달합니다. 데이터 헤더인데 드래그가 완료되었습니다. 이 데이터는 나중에 수정됩니다
자식 컴포넌트에서 상위 요소의 데이터를 직접 수정하는 것은 권장하지 않으므로 여기에서 tableHeader를 초기화하여 헤더 데이터 헤더를 호스팅합니다
하지만 헤더 수정을 허용하려면 tableHeader도 수정에 응답할 수 있습니다. 모니터 watch
watch: { header (val, oldVal) { this.tableHeader = val } }
를 추가해야 합니다. 3. 헤더
Element-UI의 Table 구성 요소를 사용자 정의하여 [drag the] 기능을 구현합니다. 열 너비 수정을 위한 테두리], mousemove, mouseup, mousedown이 없습니다. 이벤트가 노출됩니다
따라서 헤더를 사용자 정의하고 마우스 이벤트에 대한 핸들러 함수를 수동으로 추가해야 합니다. 이를 위해서는 renderHeader() 를 사용해야 합니다. method
renderHeader (createElement, {column}) { return createElement( 'p', { 'class': ['thead-cell'], on: { mousedown: ($event) => { this.handleMouseDown($event, column) }, mouseup: ($event) => { this.handleMouseUp($event, column) }, mousemove: ($event) => { this.handleMouseMove($event, column) } } }, [ // 添加 <a> 用于显示表头 label createElement('a', column.label), // 添加一个空标签用于显示拖动动画 createElement('span', { 'class': ['virtual'] }) ]) },</a>
세 가지 마우스 이벤트 중 첫 번째 매개변수가 이벤트 객체, 두 번째 매개변수가 헤더 객체입니다.
해당 처리 함수에서 해당 헤더 요소 첨자 인덱스는 columnKey를 통해 얻을 수 있습니다.
빈 라벨 드래그하는 동안 애니메이션을 표시하는 데 사용됩니다(점선)
4. 이벤트 처리
마우스를 누르면 시작 열이 기록됩니다. 마우스를 떼면 끝 열이 기록됩니다. 드래그 방향은 둘 사이의 차이를 기반으로 계산됩니다.
그런 다음 헤더 데이터는 시작 열과 끝 열의 위치에 따라 재정렬되어 열 드래그를 실현합니다.
드래깅 프로세스의 처리 기능은 다음과 같습니다.
// 按下鼠标开始拖动 handleMouseDown (e, column) { this.dragState.dragging = true this.dragState.start = parseInt(column.columnKey) // 给拖动时的虚拟容器添加宽高 let table = document.getElementsByClassName('w-table')[0] let virtual = document.getElementsByClassName('virtual') for (let item of virtual) { item.style.height = table.clientHeight - 1 + 'px' item.style.width = item.parentElement.parentElement.clientWidth + 'px' } }, // 鼠标放开结束拖动 handleMouseUp (e, column) { this.dragState.end = parseInt(column.columnKey) // 记录起始列 this.dragColumn(this.dragState) // 初始化拖动状态 this.dragState = { start: -1, end: -1, move: -1, dragging: false, direction: undefined } }, // 拖动中 handleMouseMove (e, column) { if (this.dragState.dragging) { let index = parseInt(column.columnKey) // 记录起始列 if (index - this.dragState.start !== 0) { this.dragState.direction = index - this.dragState.start min && i <p style="text-align: left;"><strong>5. 드래그 중 점선 효과</strong></p><p style="text-align: left;"> 이 과정에서 mousemove 이벤트를 통해 현재 열의 헤더 상태가 변경되고</p><p style="text-align: left;"> 그런 다음 해당 클래스가 <span style="color: #3366ff"><strong>headerCellClassName </strong></span></p><pre class="brush:php;toolbar:false">headerCellClassName ({column, columnIndex}) { return (columnIndex - 1 === this.dragState.move ? `darg_active_${this.dragState.direction}` : '') }
의 도움으로 동적으로 수정됩니다. 헤더 셀
직접 작성한 전체 스타일을 게시하세요(sass를 다음과 같이 사용). 컴파일 도구):
<style> .w-table { .el-table th { padding: 0; .virtual{ position: fixed; display: block; width: 0; height: 0; margin-left: -10px; z-index: 99; background: none; border: none; } &.darg_active_left { .virtual { border-left: 2px dotted #666; } } &.darg_active_right { .virtual { border-right: 2px dotted #666; } } } .thead-cell { padding: 0; display: inline-flex; flex-direction: column; align-items: left; cursor: pointer; overflow: initial; &:before { content: ""; position: absolute; top: 0; left: 0; bottom: 0; right: 0; } } &.w-table_moving { .el-table th .thead-cell{ cursor: move !important; } .el-table__fixed { cursor: not-allowed; } } }</style>
6. 상위 구성 요소 호출
<template> <p> <wtable> <el-table-column> </el-table-column> </wtable> </p> </template> <script> import wTable from '@/components/w-table.vue' export default { name: 'Table', data () { return { tableOption: { border: true, maxHeight: 500 }, tableHeader: [{ prop: 'name', label: '姓名', sortable: true, sortMethod: this.handleNameSort }, { prop: 'province', label: '省份', minWidth: '120' }, { prop: 'city', label: '市区', minWidth: '120' }, { prop: 'address', label: '地区', minWidth: '150' }, { prop: 'zip', label: '邮编', minWidth: '120' }], tableData: [{ date: '2016-05-03', name: '王小虎', province: '上海', city: '普陀区', address: '上海市普陀区金沙江路 1518 弄', zip: 200333 }, { date: '2016-05-02', name: '王小虎', province: '上海', city: '普陀区', address: '上海市普陀区金沙江路 1518 弄', zip: 200333 }, { date: '2016-05-04', name: '王小虎', province: '上海', city: '普陀区', address: '上海市普陀区金沙江路 1518 弄', zip: 200333 }, { date: '2016-05-01', name: '王小虎', province: '上海', city: '普陀区', address: '上海市普陀区金沙江路 1518 弄', zip: 200333 }, { date: '2016-05-08', name: '王小虎', province: '上海', city: '普陀区', address: '上海市普陀区金沙江路 1518 弄', zip: 200333 }, { date: '2016-05-06', name: '王小虎', province: '上海', city: '普陀区', address: '上海市普陀区金沙江路 1518 弄', zip: 200333 }] } }, methods: { handleNameSort () { console.log('handleNameSort') } }, components: { wTable } } </script>
믿으세요. 이 기사의 사례를 읽은 후, 더 흥미로운 정보를 보려면 PHP 중국어의 다른 관련 기사를 주목하세요. 웹사이트!
추천 자료:
위 내용은 Element-UI Table을 사용하여 드래그 앤 드롭 기능 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

각각의 엔진의 구현 원리 및 최적화 전략이 다르기 때문에 JavaScript 엔진은 JavaScript 코드를 구문 분석하고 실행할 때 다른 영향을 미칩니다. 1. 어휘 분석 : 소스 코드를 어휘 단위로 변환합니다. 2. 문법 분석 : 추상 구문 트리를 생성합니다. 3. 최적화 및 컴파일 : JIT 컴파일러를 통해 기계 코드를 생성합니다. 4. 실행 : 기계 코드를 실행하십시오. V8 엔진은 즉각적인 컴파일 및 숨겨진 클래스를 통해 최적화하여 Spidermonkey는 유형 추론 시스템을 사용하여 동일한 코드에서 성능이 다른 성능을 제공합니다.

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

이 기사에서는 Contrim에 의해 확보 된 백엔드와의 프론트 엔드 통합을 보여 주며 Next.js를 사용하여 기능적인 Edtech SaaS 응용 프로그램을 구축합니다. Frontend는 UI 가시성을 제어하기 위해 사용자 권한을 가져오고 API가 역할 기반을 준수하도록합니다.

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

Python은 데이터 과학 및 기계 학습에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명하며 데이터 분석 및 웹 개발에 적합합니다. 2. JavaScript는 프론트 엔드 개발의 핵심입니다. Node.js는 서버 측 프로그래밍을 지원하며 풀 스택 개발에 적합합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
