웹 프론트엔드 View.js Vue에서 Evernote와 같은 페이지 디자인을 구현하는 방법은 무엇입니까?

Vue에서 Evernote와 같은 페이지 디자인을 구현하는 방법은 무엇입니까?

Jun 25, 2023 pm 05:43 PM
vue 페이지 디자인 에버노트

Vue는 최신 웹 애플리케이션을 구축하는 데 사용할 수 있는 인기 있는 JavaScript 프레임워크입니다. Vue는 풍부한 대화형 UI를 개발할 수 있는 쉬운 방법을 제공하므로 많은 개발자들 사이에서 인기가 높아지고 있습니다. Evernote는 많은 기능을 제공하고 매우 독특한 인터페이스 디자인을 갖춘 잘 알려진 메모 작성 애플리케이션입니다. 이 글에서는 Vue를 사용하여 Evernote와 같은 페이지 디자인을 구현하는 방법을 소개합니다.

  1. Creating a Vue 애플리케이션

먼저 새로운 Vue 애플리케이션을 생성하겠습니다. Vue CLI를 사용하여 기본 Vue 애플리케이션을 생성할 수 있습니다. 터미널에서 다음 명령을 실행하면 됩니다.

vue create my-app
로그인 후 복사

이렇게 하면 "my-app"이라는 새로운 Vue 애플리케이션이 생성됩니다.

  1. 필요한 종속성 설치

목표를 달성하려면 몇 가지 필수 종속성을 설치해야 합니다. 다음 명령을 사용하여 설치합니다.

npm install vue-router vuex vue-fontawesome bootstrap-vue
로그인 후 복사

이렇게 하면 Vue-router, Vuex, FontAwesome 및 Bootstrap-Vue를 포함한 필수 종속성이 설치됩니다.

  1. 페이지 레이아웃 작성

다음으로, 애플리케이션에서 사용할 기본 페이지 레이아웃을 생성하겠습니다. <navbar> 구성 요소와 <sidebar> 구성 요소를 사용하여 왼쪽 사이드바를 만듭니다. 이 사이드바는 노트북과 태그가 포함된 목록으로 표시됩니다. 오른쪽에는 노트의 세부 정보를 표시하는 "NoteView"라는 구성 요소를 만듭니다. <navbar> 组件和一个 <sidebar> 组件来创建一个左侧边栏。这个边栏将以列表的形式呈现,其中包含笔记本和标签。在右侧,我们将创建一个名为 “NoteView” 的组件,用于显示笔记的详细信息。

在我们的应用程序的主组件中,我们可以使用以下代码来包含这些组件:

<template>
  <div>
    <navbar />
    <div class="container-fluid mt-5">
      <div class="row">
        <sidebar />
        <note-view />
      </div>
    </div>
  </div>
</template>

<script>
import Navbar from '@/components/Navbar.vue'
import Sidebar from '@/components/Sidebar.vue'
import NoteView from '@/components/NoteView.vue'

export default {
  components: {
    Navbar,
    Sidebar,
    NoteView
  }
}
</script>

<style>
/* Visit https://bootstrap-vue.js.org/docs/ for BootstrapVue documentation and examples */
</style>
로그인 후 복사
  1. 添加路由和 Vuex 状态管理

现在,我们需要添加路由和 Vuex 状态管理来实现我们的应用程序。我们将使用 Vuex 存储笔记本和标签,并使用路由来跳转到笔记本的详细信息页面。

我们首先需要设置一些常量,在 src/store/index.js 文件中,我们可以添加以下代码:

export const SET_NOTEBOOKS = 'SET_NOTEBOOKS'
export const SET_NOTES = 'SET_NOTES'
export const SET_TAGS = 'SET_TAGS'
export const SET_ACTIVE_NOTEBOOK = 'SET_ACTIVE_NOTEBOOK'
export const SET_ACTIVE_NOTE = 'SET_ACTIVE_NOTE'
export const ADD_NOTEBOOK = 'ADD_NOTEBOOK'
export const ADD_NOTE = 'ADD_NOTE'
export const ADD_TAG = 'ADD_TAG'
로그인 후 복사

接下来,我们将定义我们的 Vuex 状态,然后创建一个存储文件来管理这些状态。在 src/store/state.js 文件中,我们可以添加以下代码:

export default {
  notebooks: [],
  notes: [],
  tags: [],
  activeNotebook: null,
  activeNote: null
}
로그인 후 복사

接下来,我们需要设置一些动作和突变,来更新存储中的笔记本和笔记。在 src/store/mutations.js 文件中,我们可以添加以下代码:

import {
  SET_NOTEBOOKS,
  SET_NOTES,
  SET_TAGS,
  SET_ACTIVE_NOTEBOOK,
  SET_ACTIVE_NOTE,
  ADD_NOTEBOOK,
  ADD_NOTE,
  ADD_TAG
} from './index'

export default {
  [SET_NOTEBOOKS](state, notebooks) {
    state.notebooks = notebooks
  },
  [SET_NOTES](state, notes) {
    state.notes = notes
  },
  [SET_TAGS](state, tags) {
    state.tags = tags
  },
  [SET_ACTIVE_NOTEBOOK](state, notebook) {
    state.activeNotebook = notebook
  },
  [SET_ACTIVE_NOTE](state, note) {
    state.activeNote = note
  },
  [ADD_NOTEBOOK](state, notebook) {
    state.notebooks.push(notebook)
  },
  [ADD_NOTE](state, note) {
    state.notes.push(note)
  },
  [ADD_TAG](state, tag) {
    state.tags.push(tag)
  }
}
로그인 후 복사

src/store/actions.js 文件中,我们可以添加以下代码:

import axios from 'axios'

import {
  SET_NOTEBOOKS,
  SET_NOTES,
  SET_TAGS,
  SET_ACTIVE_NOTEBOOK,
  SET_ACTIVE_NOTE,
  ADD_NOTEBOOK,
  ADD_NOTE,
  ADD_TAG
} from './index'

const api = 'https://my-json-server.typicode.com/abhinav1507/demo'

export default {
  getNotebooks({ commit }) {
    axios.get(`${api}/notebooks`).then(response => {
      commit(SET_NOTEBOOKS, response.data)
    })
  },
  getNotes({ commit }) {
    axios.get(`${api}/notes`).then(response => {
      commit(SET_NOTES, response.data)
    })
  },
  getTags({ commit }) {
    axios.get(`${api}/tags`).then(response => {
      commit(SET_TAGS, response.data)
    })
  },
  setActiveNotebook({ commit }, notebook) {
    commit(SET_ACTIVE_NOTEBOOK, notebook)
  },
  setActiveNote({ commit }, note) {
    commit(SET_ACTIVE_NOTE, note)
  },
  addNotebook({ commit }, notebook) {
    axios.post(`${api}/notebooks`, notebook).then(response => {
      commit(ADD_NOTEBOOK, response.data)
    })
  },
  addNote({ commit }, note) {
    axios.post(`${api}/notes`, note).then(response => {
      commit(ADD_NOTE, response.data)
    })
  },
  addTag({ commit }, tag) {
    axios.post(`${api}/tags`, tag).then(response => {
      commit(ADD_TAG, response.data)
    })
  }
}
로그인 후 복사

接下来,在 src/router/index.js 文件中,我们需要设置路由,以在我们的应用程序中导航。我们可以添加以下代码:

import Vue from 'vue'
import Vuex from 'vuex'
import VueRouter from 'vue-router'

import Home from '@/views/Home.vue'
import Notebook from '@/views/Notebook.vue'

Vue.use(VueRouter)
Vue.use(Vuex)

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home
  },
  {
    path: '/notebook/:id',
    name: 'Notebook',
    component: Notebook
  }
]

const router = new VueRouter({
  routes
})

export default router
로그인 후 복사
  1. 实现左侧边栏

我们将使用 <sidebar> 组件来实现左侧边栏。在这个组件中,我们将呈现笔记本和标签以及添加笔记本或标签的选项。我们还将使用 FontAwesome 中的图标来对这些元素加以区分。您可以在 src/components/Sidebar.vue 文件中添加以下代码:

<template>
  <div class="col-lg-3">
    <div class="d-flex justify-content-between align-items-center mb-4">
      <h5 class="m-0">Notebooks</h5>
      <b-button variant="primary" size="sm">
        <font-awesome-icon :icon="['fas', 'plus']" />
        Add
      </b-button>
    </div>
    <b-list-group>
      <b-list-group-item v-for="notebook in notebooks" :key="notebook.id">
        <router-link :to="{ name: 'Notebook', params: { id: notebook.id}}">
          <font-awesome-icon :icon="['fas', 'book-open']" /> {{ notebook.title }}
        </router-link>
      </b-list-group-item>
    </b-list-group>
    <div class="d-flex justify-content-between align-items-center mt-4">
      <h5 class="m-0">Tags</h5>
      <b-button variant="primary" size="sm">
        <font-awesome-icon :icon="['fas', 'plus']" />
        Add
      </b-button>
    </div>
    <b-list-group>
      <b-list-group-item v-for="tag in tags" :key="tag.id">
        <font-awesome-icon :icon="['fas', 'tag']" /> {{ tag.title }}
      </b-list-group-item>
    </b-list-group>
  </div>
</template>

<script>
import { mapGetters } from 'vuex'

export default {
  computed: {
    ...mapGetters({
      notebooks: 'notebooks',
      tags: 'tags'
    })
  }
}
</script>
로그인 후 복사
  1. 实现笔记本详细页面

我们将使用一个名为 NoteView 的组件来实现笔记本详细信息页面。在这个组件中,我们将呈现笔记本的标题和内容。我们还将在笔记本的底部添加一个文本框,以便用户可以添加笔记。您可以在 src/components/NoteView.vue

우리 애플리케이션의 주요 구성 요소에는 다음 코드를 사용하여 이러한 구성 요소를 포함할 수 있습니다:
    <template>
      <div class="col-lg-9">
        <div class="d-flex justify-content-between align-items-center mb-4">
          <router-link :to="{ name: 'Home'}" class="btn btn-secondary">
            <font-awesome-icon :icon="['fas', 'arrow-left']" /> Back
          </router-link>
          <b-form-group label="Notebook" label-for="notebook">
            <b-form-select v-model="activeNotebook" :options="notebooks" id="notebook" />
          </b-form-group>
        </div>
        <div class="card">
          <div class="card-header">
            <input type="text" class="form-control" placeholder="Title">
          </div>
          <div class="card-body">
            <textarea class="form-control" placeholder="Note"></textarea>
          </div>
        </div>
      </div>
    </template>
    
    <script>
    import { mapGetters, mapActions } from 'vuex'
    
    export default {
      computed: {
        ...mapGetters({
          notebooks: 'notebooks',
          activeNotebook: 'activeNotebook'
        })
      },
      methods: {
        ...mapActions({
          setActiveNotebook: 'setActiveNotebook'
        })
      },
      created() {
        if (!this.activeNotebook && this.notebooks.length) {
          this.setActiveNotebook(this.notebooks[0])
        }
      }
    }
    </script>
    로그인 후 복사
    1. 라우팅 및 Vuex 상태 관리 추가

    이제 라우팅 및 Vuex 상태 관리를 추가해야 합니다. 우리의 응용 프로그램을 구현합니다. Vuex를 사용하여 노트북과 태그를 저장하고 라우팅을 사용하여 노트북의 세부 정보 페이지로 이동합니다.

    🎜먼저 몇 가지 상수를 설정해야 합니다. src/store/index.js 파일에 다음 코드를 추가할 수 있습니다. 🎜rrreee🎜다음으로 Vuex 상태를 정의한 다음 이러한 상태를 관리하려면 파일을 저장하세요. src/store/state.js 파일에 다음 코드를 추가할 수 있습니다: 🎜rrreee🎜 다음으로 스토어의 노트북과 노트를 업데이트하기 위한 몇 가지 작업과 변형을 설정해야 합니다. src/store/mutations.js 파일에 다음 코드를 추가할 수 있습니다. 🎜rrreee🎜 src/store/actions.js 파일에 다음 코드를 추가할 수 있습니다. 다음 코드 :🎜rrreee🎜다음으로 src/router/index.js 파일에서 애플리케이션 내에서 탐색할 경로를 설정해야 합니다. 다음 코드를 추가할 수 있습니다: 🎜rrreee
      🎜왼쪽 사이드바 구현🎜🎜🎜<sidebar> 구성 요소를 사용하여 왼쪽 사이드바를 구현하겠습니다. 이 구성 요소에서는 노트북 또는 탭을 추가하는 옵션과 함께 노트북 및 탭을 제공합니다. 또한 이러한 요소를 구별하기 위해 FontAwesome의 아이콘을 사용할 것입니다. src/comComponents/Sidebar.vue 파일에 다음 코드를 추가할 수 있습니다: 🎜rrreee
        🎜노트북 세부 정보 페이지 구현🎜🎜🎜우리는 NoteView 구성 요소를 사용하여 노트북 세부 정보 페이지를 구현합니다. 이 구성 요소에서는 노트북의 제목과 내용을 렌더링합니다. 또한 사용자가 메모를 추가할 수 있도록 노트북 하단에 텍스트 상자를 추가할 것입니다. src/comComponents/NoteView.vue 파일에 다음 코드를 추가할 수 있습니다. 🎜rrreee🎜🎜Done🎜🎜🎜이제 Vue 애플리케이션에 Evernote와 유사한 페이지 디자인을 구현했습니다. 컴포넌트와 라우팅을 사용하여 왼쪽 사이드바와 노트 세부정보 페이지를 구현하고 Vuex 상태 관리를 사용하여 노트북, 노트, 태그를 저장합니다. 또한 FontAwesome과 Bootstrap-Vue를 사용하여 UI를 최적화했습니다. 이 Vue 애플리케이션을 기반으로 더 많은 스타일과 기능을 추가하고 확장할 수 있습니다. 🎜

    위 내용은 Vue에서 Evernote와 같은 페이지 디자인을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Vue 용 버튼에 기능을 추가하는 방법 Vue 용 버튼에 기능을 추가하는 방법 Apr 08, 2025 am 08:51 AM

HTML 템플릿의 버튼을 메소드에 바인딩하여 VUE 버튼에 함수를 추가 할 수 있습니다. 메소드를 정의하고 VUE 인스턴스에서 기능 로직을 작성하십시오.

Vue에서 부트 스트랩을 사용하는 방법 Vue에서 부트 스트랩을 사용하는 방법 Apr 07, 2025 pm 11:33 PM

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

Vue에서 시계를 사용하는 방법 Vue에서 시계를 사용하는 방법 Apr 07, 2025 pm 11:36 PM

vue.js의 시계 옵션을 사용하면 개발자가 특정 데이터의 변경 사항을들을 수 있습니다. 데이터가 변경되면 콜백 기능을 트리거하여 업데이트보기 또는 기타 작업을 수행합니다. 구성 옵션에는 즉시 콜백을 실행할지 여부와 DEEP를 지정하는 즉시 포함되며, 이는 객체 또는 어레이에 대한 변경 사항을 재귀 적으로 듣는 지 여부를 지정합니다.

vue.js로 JS 파일을 참조하는 방법 vue.js로 JS 파일을 참조하는 방법 Apr 07, 2025 pm 11:27 PM

vue.js에서 JS 파일을 참조하는 세 가지 방법이 있습니다. & lt; script & gt; 꼬리표;; mounted () 라이프 사이클 후크를 사용한 동적 가져 오기; Vuex State Management Library를 통해 수입.

Vue 다중 페이지 개발은 무엇을 의미합니까? Vue 다중 페이지 개발은 무엇을 의미합니까? Apr 07, 2025 pm 11:57 PM

VUE 멀티 페이지 개발은 vue.js 프레임 워크를 사용하여 응용 프로그램을 구축하는 방법입니다. 여기서 응용 프로그램은 별도의 페이지로 나뉩니다. 코드 유지 보수 : 응용 프로그램을 여러 페이지로 분할하면 코드를보다 쉽게 ​​관리하고 유지 관리 할 수 ​​있습니다. 모듈 식 : 각 페이지는 쉬운 재사용 및 교체를 위해 별도의 모듈로 사용할 수 있습니다. 간단한 라우팅 : 페이지 간의 탐색은 간단한 라우팅 구성을 통해 관리 할 수 ​​있습니다. SEO 최적화 : 각 페이지에는 자체 URL이있어 SEO가 도움이됩니다.

VUE 버전을 쿼리하는 방법 VUE 버전을 쿼리하는 방법 Apr 07, 2025 pm 11:24 PM

Vue DevTools를 사용하여 브라우저 콘솔에서 vue 탭을 보면 VUE 버전을 쿼리 할 수 ​​있습니다. npm을 사용하여 "npm list -g vue"명령을 실행하십시오. package.json 파일의 "종속성"객체에서 vue 항목을 찾으십시오. Vue Cli 프로젝트의 경우 "vue -version"명령을 실행하십시오. & lt; script & gt에서 버전 정보를 확인하십시오. vue 파일을 나타내는 html 파일의 태그.

Vue가 이전 페이지로 돌아 오는 방법 Vue가 이전 페이지로 돌아 오는 방법 Apr 07, 2025 pm 11:30 PM

vue.js는 이전 페이지로 돌아갈 수있는 네 가지 방법이 있습니다. $ router.go (-1) $ router.back () 사용 & lt; router-link to = & quot;/quot; Component Window.history.back () 및 메소드 선택은 장면에 따라 다릅니다.

함수 인터셉트 vue를 사용하는 방법 함수 인터셉트 vue를 사용하는 방법 Apr 08, 2025 am 06:51 AM

VUE의 기능 차단은 지정된 기간 내에 기능이 호출되는 횟수를 제한하고 성능 문제를 방지하는 데 사용되는 기술입니다. 구현 방법은 다음과 같습니다. lodash 라이브러리 가져 오기 : 'lodash'에서 import {debounce}; Debounce 기능을 사용하여 인터셉트 기능을 만듭니다. const debouncedfunction = debounce (() = & gt; { / logical /}, 500); 인터셉트 함수를 호출하면 제어 기능이 최대 500 밀리 초 안에 한 번 호출됩니다.

See all articles