최신 웹 애플리케이션에서 드래그 앤 드롭 기능은 사용자에게 더 나은 대화형 경험을 제공할 수 있기 때문에 표준 기능 중 하나가 되었습니다. 이 기사에서는 Go 언어와 React를 사용하여 드래그 가능한 목록을 작성하여 웹 애플리케이션을 더 사용하기 쉽고 흥미롭게 만드는 방법을 소개합니다.
1단계: 백엔드 서비스 구축
먼저 목록 데이터를 관리하기 위한 백엔드 서비스를 구축해야 합니다. Go 언어를 사용하여 간단한 REST API를 만들어 보겠습니다. 코드를 단순화하기 위해 Gin 프레임워크와 GORM 라이브러리를 모두 사용합니다.
먼저 목록 항목을 저장하기 위해 "items"라는 테이블을 만들어야 합니다.
CREATE TABLE items ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, position INT NOT NULL, PRIMARY KEY (id) );
다음으로 Golang 파일을 만들고 여기에 다음 코드를 추가합니다.
package main import ( "github.com/gin-gonic/gin" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type Item struct { ID int `gorm:"primary_key" json:"id"` Name string `gorm:"not null" json:"name"` Position int `gorm:"not null" json:"position"` } func main() { // 初始化Gin框架 r := gin.Default() // 连接MySQL数据库 db, err := gorm.Open("mysql", "{username}:{password}@/{database_name}?charset=utf8&parseTime=True&loc=Local") if err != nil { panic("无法连接到数据库") } defer db.Close() // 自动迁移schema db.AutoMigrate(&Item{}) // 添加CORS中间件 r.Use(corsMiddleware()) // 定义API路由 api := r.Group("/api") { api.GET("/items", listItems) api.PUT("/items/:id", updateItem) } // 启动服务 r.Run(":8080") } // 列出所有项 func listItems(c *gin.Context) { db := c.MustGet("db").(*gorm.DB) var items []Item db.Find(&items) c.JSON(200, items) } // 更新单个项目 func updateItem(c *gin.Context) { db := c.MustGet("db").(*gorm.DB) // 从URL参数获得项目的ID id := c.Param("id") // 从请求体得到项目的其他项(名称和位置) var input Item if err := c.BindJSON(&input); err != nil { c.JSON(400, gin.H{"error": err.Error()}) return } // 更新数据库 var item Item if db.First(&item, id).RecordNotFound() { c.JSON(404, gin.H{"error": "项目未找到"}) return } item.Name = input.Name item.Position = input.Position if err := db.Save(&item).Error; err != nil { c.JSON(400, gin.H{"error": "更新项目失败"}) return } c.JSON(200, item) } // 添加CORS中间件 func corsMiddleware() gin.HandlerFunc { return func(c *gin.Context) { c.Writer.Header().Set("Access-Control-Allow-Origin", "*") c.Writer.Header().Set("Access-Control-Allow-Methods", "GET, PUT, POST, DELETE, OPTIONS") c.Writer.Header().Set("Access-Control-Allow-Headers", "Content-Type") c.Writer.Header().Set("Access-Control-Max-Age", "86400") if c.Request.Method == "OPTIONS" { c.AbortWithStatus(200) return } c.Next() } }
이 코드에서는 먼저 목록 항목을 저장하기 위해 "items"라는 테이블을 만듭니다. 그런 다음 "Item"이라는 구조체를 만들고 그 안에 해당 필드를 정의했습니다. 다음으로, 데이터베이스에서 모든 항목을 가져와 JSON으로 반환하는 "listItems"라는 함수를 만들었습니다. 또한 단일 항목을 업데이트하는 "updateItem"이라는 함수도 만들었습니다.
이 Golang 파일에 "api"라는 라우팅 그룹을 만들고 GET /items 및 PUT /items/:id라는 두 가지 경로를 정의했습니다. GET 경로는 모든 항목을 가져오는 데 사용되고 PUT 경로는 단일 항목을 업데이트하는 데 사용됩니다.
CORS 문제를 처리하기 위해 "corsMiddleware"라는 미들웨어도 추가했습니다. CORS를 사용하면 한 도메인의 코드가 다른 도메인의 API에 요청할 수 있습니다. 이는 웹 애플리케이션을 개발할 때 매우 일반적입니다.
2단계: React 프런트엔드 구축
다음으로 React 프런트엔드를 생성해야 합니다. React와 React-DnD 라이브러리를 사용하여 드래그 앤 드롭 기능을 구현하겠습니다. 또한 Axios 라이브러리를 사용하여 백엔드 서버에서 데이터를 가져옵니다.
먼저 "ItemList"라는 폴더를 만들고 다음 코드를 "ItemList.jsx"라는 파일에 저장해야 합니다.
import React, { useState, useEffect } from 'react'; import axios from 'axios'; import { DragDropContext, Droppable, Draggable } from 'react-beautiful-dnd'; export default function ItemList() { const [items, setItems] = useState([]); useEffect(() => { axios.get('http://localhost:8080/api/items').then((response) => { setItems(response.data); }); }, []); function onDragEnd(result) { const { destination, source, draggableId } = result; if (!destination) { return; } if ( destination.droppableId === source.droppableId && destination.index === source.index ) { return; } const item = items.find((i) => i.id === parseInt(draggableId)); const newItems = [...items]; newItems.splice(source.index, 1); newItems.splice(destination.index, 0, item); axios .put(`http://localhost:8080/api/items/${draggableId}`, { name: item.name, position: destination.index, }) .then(() => { setItems(newItems); }); } return ( <DragDropContext onDragEnd={onDragEnd}> <Droppable droppableId="itemList"> {(provided) => ( <ul {...provided.droppableProps} ref={provided.innerRef} className="item-list" > {items.map((item, index) => { return ( <Draggable key={item.id} draggableId={item.id.toString()} index={index} > {(provided) => ( <li {...provided.draggableProps} {...provided.dragHandleProps} ref={provided.innerRef} className="item" > {item.name} </li> )} </Draggable> ); })} {provided.placeholder} </ul> )} </Droppable> </DragDropContext> ); }
이 React 구성 요소에서는 먼저 useState와 useEffect를 사용하여 목록의 데이터를 가져옵니다. 안건. 그런 다음 드래그 이벤트를 처리하고 데이터를 업데이트하기 위해 "onDragEnd"라는 함수를 만들었습니다. 또한 React-DnD 라이브러리를 사용하여 드래그 가능한 목록을 만들었습니다. 이 "ItemList" 구성 요소에서는 모든 목록 항목을 포함하는
- 요소를 렌더링하고
이제 애플리케이션에서 이 구성요소를 사용해야 합니다. React 애플리케이션에서는 "App"이라는 구성 요소를 만들고 JSX에
import React from 'react'; import ReactDOM from 'react-dom'; import App from './App'; ReactDOM.render(<App />, document.getElementById('root'));
3단계: 애플리케이션 실행
이제 애플리케이션 개발이 완료되었습니다. 백엔드 서비스와 프론트엔드 React 애플리케이션을 시작하여 실행을 확인해야 합니다. 먼저 터미널 창을 두 번 열고 한 창에서 Go 애플리케이션 디렉터리로 전환한 후 다음 명령을 실행해야 합니다.
go run main.go
그런 다음 다른 터미널 창에서 React 애플리케이션 디렉터리로 전환하고 다음 명령을 실행합니다.
npm start
이제 브라우저에서 http://localhost:3000/을 방문하면 드래그 가능한 목록을 볼 수 있습니다. 이제 목록 항목을 편안하게 드래그하여 백엔드 서비스에서 적절하게 업데이트할 수 있는지 확인해 볼 수 있습니다.
결론
이 기사에서는 Go 언어와 React를 사용하여 드래그 가능한 목록을 작성했습니다. Gin 및 React-DnD 라이브러리를 통해 목록 항목 드래그 기능을 구현하고 백엔드에서 Axios 라이브러리를 전달했습니다. 데이터. 이 샘플 프로젝트는 일상적인 작업 개발 시 참조로 사용할 수 있습니다.
위 내용은 Go와 React를 사용하여 드래그 가능한 목록을 만드는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

goisidealforbuildingscalablesystemsduetoitssimplicity, 효율성 및 빌드-내부 컨 컨 오렌 스upport.1) go'scleansyntaxandminimalisticdesignenenhance-reductivityandreduceerrors.2) itsgoroutinesandChannelsableefficedsoncurrentProgramming, DistributingLoa

initTectionsIntOnaUtomaticallyBeforemain () andAreSefulforsettingupenvirondentAnitializingVariables.usethemforsimpletasks, propoysideeffects 및 withtestingntestingandloggingtomaincodeclarityAndestability.

goinitializespackages는 theyareimported, theexecutesinitfunctions, theneiredefinitionorder, andfilenamesDeterMineDeTerMineTeRacrossMultipleFiles.ThemayLeadTocomplexInitializations의 의존성 의존성의 의존성을 확인합니다

CustomInterfacesingoAreCrucialForwritingFlectible, 관리 가능 및 TestAblEcode.theyenabledeveloperstofocusonBehaviorimplementation, 향상 ModularityAndRobustness

시뮬레이션 및 테스트에 인터페이스를 사용하는 이유는 인터페이스가 구현을 지정하지 않고 계약의 정의를 허용하여 테스트를보다 고립되고 유지 관리하기 쉽기 때문입니다. 1) 인터페이스를 암시 적으로 구현하면 테스트에서 실제 구현을 대체 할 수있는 모의 개체를 간단하게 만들 수 있습니다. 2) 인터페이스를 사용하면 단위 테스트에서 서비스의 실제 구현을 쉽게 대체하여 테스트 복잡성과 시간을 줄일 수 있습니다. 3) 인터페이스가 제공하는 유연성은 다른 테스트 사례에 대한 시뮬레이션 동작의 변화를 허용합니다. 4) 인터페이스는 처음부터 테스트 가능한 코드를 설계하여 코드의 모듈성과 유지 관리를 향상시키는 데 도움이됩니다.

GO에서는 INT 기능이 패키지 초기화에 사용됩니다. 1) INT 기능은 패키지 초기화시 자동으로 호출되며 글로벌 변수 초기화, 연결 설정 및 구성 파일로드에 적합합니다. 2) 파일 순서로 실행할 수있는 여러 개의 초기 함수가있을 수 있습니다. 3)이를 사용할 때 실행 순서, 테스트 난이도 및 성능 영향을 고려해야합니다. 4) 부작용을 줄이고, 종속성 주입을 사용하고, 초기화를 지연하여 초기 기능의 사용을 최적화하는 것이 좋습니다.

go'selectStatementsTreamLinesconcurramprogrammingBymultiplexingOperations.1) ItallowSwaitingOnMultipLechannelOperations, executingThefirStreadYone.2) thedefaultCasePreventsDeadLocksHavingThepRamToproCeedifNooperationSready.3) Itcanusedfored

Contextandwaitgroupsarecrucialingformaninggoroutineeseforoutineeseferfectial


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
