Wish Sticky Note App with Vue.js

HTMLHTMLBeginner
Practice Now

Introduction

In this project, you will learn how to create a "Wish Sticky Note" application using Vue.js and the Element-UI library. The project aims to provide an anonymous and convenient platform for people to express their goals, ideals, and aspirations in a safe and confidential manner.

๐Ÿ‘€ Preview

The following error will be reported when the field validation conditions are not met:

Form validation error message

After fulfilling the conditions and posting the wish, the effect is as follows:

Completed Effect

๐ŸŽฏ Tasks

In this project, you will learn:

  • How to set up the project structure and prepare the necessary files and folders.
  • How to render the completed form on the wish wall.
  • How to implement form validation to ensure that the input fields meet the required criteria.
  • How to handle form submission and reset functionality.
  • How to implement image upload and preview functionality.

๐Ÿ† Achievements

After completing this project, you will be able to:

  • Structure and organize a Vue.js project.
  • Use the Element-UI library to create forms and handle user interactions.
  • Implement form validation using the Element-UI validation rules.
  • Handle file uploads and image previews in a Vue.js application.
  • Manage state and update the UI based on user actions.

Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL html(("`HTML`")) -.-> html/BasicStructureGroup(["`Basic Structure`"]) html(("`HTML`")) -.-> html/LayoutandSectioningGroup(["`Layout and Sectioning`"]) html(("`HTML`")) -.-> html/FormsandInputGroup(["`Forms and Input`"]) html(("`HTML`")) -.-> html/AdvancedElementsGroup(["`Advanced Elements`"]) html/BasicStructureGroup -.-> html/head_elems("`Head Elements`") html/LayoutandSectioningGroup -.-> html/layout("`Layout Elements`") html/FormsandInputGroup -.-> html/forms("`Form Elements`") html/FormsandInputGroup -.-> html/form_valid("`Form Validation`") html/FormsandInputGroup -.-> html/form_access("`Accessibility in Forms`") html/AdvancedElementsGroup -.-> html/inter_elems("`Interactive and Dynamic Elements`") subgraph Lab Skills html/head_elems -.-> lab-445638{{"`Wish Sticky Note App with Vue.js`"}} html/layout -.-> lab-445638{{"`Wish Sticky Note App with Vue.js`"}} html/forms -.-> lab-445638{{"`Wish Sticky Note App with Vue.js`"}} html/form_valid -.-> lab-445638{{"`Wish Sticky Note App with Vue.js`"}} html/form_access -.-> lab-445638{{"`Wish Sticky Note App with Vue.js`"}} html/inter_elems -.-> lab-445638{{"`Wish Sticky Note App with Vue.js`"}} end

Set Up the Project Structure

In this step, you will set up the project structure and prepare the necessary files and folders.

Open the project folder in your code editor. The directory structure is as follows:

โ”œโ”€โ”€ css
โ”‚   โ”œโ”€โ”€ fonts
โ”‚   โ”‚   โ”œโ”€โ”€ element-icons.ttf
โ”‚   โ”‚   โ””โ”€โ”€ element-icons.woff
โ”‚   โ”œโ”€โ”€ index.css
โ”‚   โ””โ”€โ”€ wish.css
โ”œโ”€โ”€ images
โ”‚   โ”œโ”€โ”€ bg.jfif
โ”‚   โ””โ”€โ”€ ding.png
โ”œโ”€โ”€ index.html
โ””โ”€โ”€ js
    โ”œโ”€โ”€ index.js
    โ””โ”€โ”€ vue.min.js

Where:

  • css is the folder where the project styles for element-ui are stored.
  • images is the image folder.
  • index.html is the main page.
  • js is the folder for the project's dependent JavaScript libraries.

Click on Go Live button in the bottom right corner of WebIDE, to run the project.

Next, open "Web 8080" on the top of the VM and manually refresh it to see the page.

The page doesn't do validation of the input box during initialization and the wishing post doesn't appear after the input is posted.

Render the Completed Form on the Wish Wall

In this step, you will modify the index.html file to render the completed form on the wish wall.

  1. Open the index.html file in the project folder.
  2. Find the TODO comment in the index.html file and after observing the problem in the code, I found that the code in v-for="(item,index) in []" is problematic and changed it to the following code:
<!-- TODO -->
<div
  class="card"
  :class="item.css"
  v-for="(item,index) in wishList"
  :key="index"
>
  <!-- ... -->
</div>

The code in the <div> element with the class="card" attribute will display the name, content, and image (if available) of the completed form on the wish wall.

Implement Form Validation

In this step, you will complete the form validation to ensure that the input fields meet the required criteria.

  1. Open the index.html file in the project folder.
  2. Find the rules object in the data section of your Vue instance to add the following code:
rules: {
  // TODO
  name: [
    {
      required: true,
      message: "Please input your name",
      trigger: "blur"
    },
    {
      min: 2,
      max: 4,
      message: "Length should be between 2 and 4 characters",
      trigger: "blur"
    }
  ],
  content: [
    {
      required: true,
      message: "Please input content",
      trigger: "blur"
    },
    {
      min: 1,
      max: 30,
      message: "Length should be between 1 and 30 characters",
      trigger: "blur"
    }
  ]
},
  1. In the name and content properties of the rules object, define the validation rules:

    • name: The name field is required and must be between 2 and 4 characters long.
    • content: The content field is required and must be between 1 and 30 characters long.
  2. With these validation rules in place, the form will now display error messages when the input fields do not meet the specified criteria.

Form validation error display
  1. After fulfilling the conditions and posting the wish, the effect is as follows:
Completed Effect
โœจ Check Solution and Practice

Summary

Congratulations! You have completed this project. You can practice more labs in LabEx to improve your skills.

Other HTML Tutorials you may like