Indexed DatabaseAPI를 사용하여 독립형 메모장 응용 프로그램 만들기
5948 단어 JavaScriptVue.js
글의 취지
가까스로 Indexed DatabaseAPI 학습 브라우저 프로그램을 만들었다.
1. 제작된 어플리케이션과 기술적 요소
브라우저에 점성(메모지) 같은 필기를 남길 수 있는 도구입니다. 판넬 방식의 관리 도구를 만들려고 했는데 기진맥진해서 잠시 보류했습니다. 화면 캡처는 다음과 같습니다.
사용하는 기술 요소는 다음과 같다.js는 첫 접촉이기 때문에 책을 쳐다보는 대응이다.
2. 조작 방법
나는 직감으로 처리하는 수준이라고 생각한다. 한마디로 하면 다음과 같다.
kanban.html
. 3. 고전의 요점
기술이 낮기 때문에 초보적이고 어리석은 것들이지만 치욕을 참으며 글을 쓴다.
3.1 Promise
다음 처리는 "DB와의 연결 확립"-> "모든 티켓 취득"-> "전역 변수에 티켓 정보를 기입"하려는 의도의 코드입니다. 그 중에서
createConnection()
및 getAllTickets()
는 반환Promise
대상의 함수입니다.Indexed DatabaseAPI는 비동기식 처리이므로 활용Promise
을 통해 동기화를 도모합니다. created: function() {
createConnection().then(
getAllTickets()
).then(
(allTickets) => {
allTickets.forEach(
ticket =>
{
tickets.push({
id: ticket.id,
text: ticket.text,
url: ticket.url,
categoryId: ticket.categoryId,
left: ticket.left,
top: ticket.top,
zIndex: ticket.zIndex,
deleted: false
})
}
)
}
).catch(
(reason) => alert(reason)
)
}
그러면 상술한 코드의 일부분은 정당하지 않아서 동기화 처리를 할 수 없다.답안은 세 번째 줄로 쓰여 있습니다.
getAllTicket()
, 여기는 getAllTicket
함수 대상을 지정해야 합니다.promise.prototype.then()
시종일관 방법이며, 매개 변수 지정은 리셋 함수입니다. 매우 어리석은 오류이지만 조심하지 않아 if/else의 문법과 같은 느낌으로 기술하여 상술한 오류를 초래했습니다.3.2 Bubbling
이번 메모지의 대상은 여러 층으로 구성되어 있기 때문에 버블링이 사건을 처리하는 것을 의식해야 하지만 이 점을 전혀 이해하지 못해 시퀀스는 상당히 무의식적인 행동에 시달렸다.
Bubbling에 관해서는 며칠 전 보도 이해하기 쉽다고 생각합니다. 인용 정의는 다음과 같습니다.
원소에 이벤트가 발생하면 먼저 위의 처리 프로그램을 실행한 다음에 다른 조상에게 도착할 때까지 상위 처리 프로그램을 실행합니다.
이번에는 "URL"단추를 누르면 메모지 자체에 설치된 마우스 하강 사건을 계속 처리한다. 후자는 메모지의 이동과 관련된 처리이기 때문에 메모지가 비뚤어지는 등 신비로운 행위가 빈번하게 발생한다.
버블링을 방지하려면 호출
event.stopPropagation()
을 통해 나중에 부모 대상에게 전파되는 것을 억제할 수 있다.4. 업무
Reference
이 문제에 관하여(Indexed DatabaseAPI를 사용하여 독립형 메모장 응용 프로그램 만들기), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/nk5jp/items/2541cf6026ec85fd346e텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)