<h4>Repository
<p dir="auto"><span><a href="https://github.com/vuejs/vue" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/vuejs/vue
<h4>What Will I Learn?
<ul>
<li>You will learn about List Rendering Concepts.
<li>You will learn about Replacing an Array.
<li>You will learn about Mutation Methods.
<li>You will learn about <code>v-for function.
<li>You will learn how to create To-Do application with using components.
<li>You will learn how to use <code>:key with <code>v-for function.
<li>You will learn about <code>splice mutation method.
<li>You will learn about <code>push mutation method.
<li>You will learn about <code>@submit.prevent feature.
<li>You will learn about <strong>script must be a function rule.
<li>You will learn how to use <code>v-if with <code>v-for.
<li>You will learn how to create transparent text in placeholder.
<h4>Timeline
<p dir="auto"><strong>00:00 Intro.<br />
<strong>00:46 Information About To-Do List.<br />
<strong>01:00 Information About "Why we use Materialize and Vue.js v2?".<br />
<strong>01:21 Brief Information About Replacing an Array Feature.<br />
<strong>01:41 Brief Information About Mutation Methods (Sub-feature of List Rendering).<br />
<strong>02:07 Brief Information About <strong>push Mutation Method<br />
<strong>02:22 Brief Information About <strong>splice Mutation Method<br />
<strong>03:26 Brief Information About <code>v-for, <code>:key and <code>v-for with a component.<br />
<strong>05:13 Information About Script Resources.<br />
<strong>05:23 Defining To-Do List Main ID<br />
<strong>05:58 Information About <code>@submit.prevent.<br />
<strong>06:32 Brief Information About Two Way Data Binding.<br />
<strong>06:54 Information about <code>v-model.<br />
<strong>07:43 Creating first button (Add Something To Do button)<br />
<strong>08:16 Creating Components and Information About <code>v-for and <code>:key.<br />
<strong>11:38 Creating a Field for To-Dos<br />
<strong>12:53 Creating Actions-ToDo-List div class for buttons.<br />
<strong>13:28 Defining Done and Remove buttons properties and tasks with using <code>@click and <code>v-if function.<br />
<strong>14:51 Brief Information about <code>index parameter.<br />
<strong>15:25 Defining Little CSS Codes.<br />
<strong>16:10 Creating new Vue Instance elements and components.<br />
<strong>16:43 Defining data as <strong>data must be a function.<br />
<strong>17:14 Information about <code>return.<br />
<strong>18:03 Information About "Why we need to use Computed Properties when we creating To-Do List Application?"<br />
<strong>19:33 Defining Mutation Methods<br />
<strong>19:54 Information About <code>push mutation method.<br />
<strong>20:41 Information about <code>title: this.newTodo.<br />
<strong>21:58 Information About <code>splice mutation method and <code>index parameter.<br />
<strong>23:40 Testing our Work.<br />
<strong>24:33 Checking for Error with Inspect Element Console.<br />
<strong>24:53 Ending.
<h4>Requirements
<ul>
<li>Vue.js version 2.5.16 (Full Library).
<li>Materialize Minified CSS Package 1.0.0-beta version.
<li>Microsoft Visual Studio Code. (or another text editor.)
<li>A browser for testing.
<li>XAMPP Control Panel Server.
<h4>OS Requirements for Running Materialize and Vue.js v2
<ul>
<li>Linux (64-bit)
<li>Windows 7 / Windows 8 / Windows 8.1 and Windows 10.
<li>macOS (64-bit)
<h4>Difficulty
<ul>
<li>Intermediate
<h4>Description
<h5>A Small Overview
<p dir="auto">Firstly we talked about <strong>To-Do List, <strong>List Rendering, <strong>Replacing an Array, <strong>Mutation Methods (splice & push), <strong>Two Way Data Binding, <strong>Computed Properties, <strong>Index Parameter, <strong>v-for and more. After that we defined our <strong>To-Do List's HTML body codes. I gave detailed information about all the codes and functions we have defined. We defined <code>v-model, <code>v-for, <code>v-if and <code>v-for :key at the HTML body codes. We defined <code>v-for <code>:key's task for <strong>completed tasks. After many operations, In the script section we learned how to use <strong>mutation methods and "data must be a function" rule. And we also learned how to use <code>push and <code>splice mutation methods and we learned <strong>how to trigger the push and splice mutation methods. We finally learned how to use <code>splice method with <code>index parameter.<br />
Finally, I gave technical information about all of classes, components, codes, elements, mutation methods, special features, important concepts, variables and all operations. Vue.js tutorial series will progress from intermediate to advanced. All the programs and scripts described in the video (Vue.js Version 2, Materialize CSS Minified Package Version 1-0-0, Visual Studio Code, XAMPP Server Control Panel Server) are open source and are all included in the links section of the <strong>GitHub repositories (Except XAMPP Control Panel Server). If you wish, you can access the web pages of these programs and download links for Windows from the <strong>All of Resources for this Project section.
<h4>All of Resources for this Project
<ul>
<li><span>Vue.js Github Repo: <a href="https://github.com/vuejs/vue" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/vuejs/vue
<li><span>Vue.js Installation Page: <a href="https://vuejs.org/v2/guide/installation.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/installation.html
<li>Vue.js Main Logo: <a href="https://vuejs.org/images/logo.png" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Image
<li><span>Vue.js Documentation Guide: <a href="https://vuejs.org/v2/guide/index.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/index.html
<li><span>Visual Studio Code (VSCode) GitHub Repo: <a href="https://github.com/Microsoft/vscode" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/Microsoft/vscode
<li><span>Materialize Web Site: <a href="https://vuejs.org" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org
<li><span>Materialize Minified CSS Library: <a href="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.100.2/css/materialize.min.css" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://cdnjs.cloudflare.com/ajax/libs/materialize/0.100.2/css/materialize.min.css
<li><span>Vue.js CDN: <a href="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js
<li><span>Visual Studio Code Web Site: <a href="https://code.visualstudio.com/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://code.visualstudio.com/
<li><span>Visual Studio Code Download Link for Win x64: <a href="https://go.microsoft.com/fwlink/?Linkid=852157" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://go.microsoft.com/fwlink/?Linkid=852157
<li><span>XAMPP Control Panel Server Web Site: <a href="https://www.apachefriends.org/en/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://www.apachefriends.org/en/
<li><span>XAMPP Control Panel Server (For Windows) Download Link: <a href="https://www.apachefriends.org/download.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://www.apachefriends.org/download.html
<h4>Knowledge Resources (Wiki)
<ul>
<li><span>Vue.js Knowledge: <a href="https://vuejs.org/v2/guide/index.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/index.html
<li><span>Vue.js Brief Knowledge (Unofficial): <a href="https://wiki.base22.com/btg/vue-the-progressive-javascript-framework-116392407.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://wiki.base22.com/btg/vue-the-progressive-javascript-framework-116392407.html
<li><span>Vue.js List Rendering Knowledge: <a href="https://vuejs.org/v2/guide/list.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/list.html
<li><span>Vue.js Computed Properties Knowledge for Version 2: <a href="https://vuejs.org/v2/guide/computed.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/computed.html
<li><span>CSS Knowledge (wiki): <a href="https://www.w3schools.com/w3css/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://www.w3schools.com/w3css/
<li><span>Vue.js Render Functions and Virtual DOM: <a href="https://vuejs.org/v2/guide/render-function.html#The-Virtual-DOM" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/render-function.html#The-Virtual-DOM
<li><span>Vue.js Components Knowledge: <a href="https://vuejs.org/v2/guide/components.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/components.html
<li><span>Vue.js Replacing an Array Knowledge: <a href="https://vuejs.org/v2/guide/list.html#Replacing-an-Array" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/list.html#Replacing-an-Array
<li><span>Vue.js Two way data binding Knowledge for version 1: <a href="https://012.vuejs.org/guide/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://012.vuejs.org/guide/
<li><span>Vue.js Two way data binding Knowledge for version 2: <a href="https://vuejs.org/v2/guide/forms.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/forms.html
<li>Vue.js Components on <code>v-model<span> Knowledge: <a href="https://vuejs.org/v2/guide/components.html#Using-v-model-on-Components" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/components.html#Using-v-model-on-Components
<li>Vue.js Form Input Bindings and <code>v-model<span> Knowledge: <a href="https://vuejs.org/v2/guide/forms.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/forms.html
<li>Vue.js <code>@submit.prevent<span> Knowledge: <a href="https://vuejs.org/v2/guide/events.html#Event-Modifiers" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/events.html#Event-Modifiers
<li><span>Vue.js Mutation Methods Knowledge: <a href="https://vuejs.org/v2/guide/list.html#Mutation-Methods" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/list.html#Mutation-Methods
<li>Vue.js <code>v-if with <code>v-for Knowledge:<br /><span>
<a href="https://vuejs.org/v2/guide/conditional.html#v-if-with-v-for" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/conditional.html#v-if-with-v-for
<li>Vue.js <code>:key<span> Knowledge: <a href="https://vuejs.org/v2/guide/list.html#key" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://vuejs.org/v2/guide/list.html#key
<h4>Cover Image Source
<p dir="auto"><a href="http://i68.tinypic.com/4kv8l0.jpg" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Image
<p dir="auto">The source code and project file for this tutorial can be found <a href="https://github.com/sargoon/sargoon_vue2_todo_list/blob/master/todo-app-sargoon.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">here..
<h3>Summary: Important Points
<h4>Creating HTML Body Skeleton for To-Do List Application
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i66.tinypic.com/k128mf.png" srcset="https://images.hive.blog/768x0/http://i66.tinypic.com/k128mf.png 1x, https://images.hive.blog/1536x0/http://i66.tinypic.com/k128mf.png 2x" />
<p dir="auto">In the first step, we defined a division ID as <strong>todoapp. This ID is very important for our project because when we write Vue.js special scripts and methods, we will need this ID.<br />
And on the bottom line, we defined two division class for container and header. These division classes are simple commands for creating a field.<br />
And after that we defined an header for our To-Do List. The header will appear above the To-Do List and in the center of the page.
<h4>Creating an input type with Two Way Data Binding Feature, Creating <code>addTodo<code>v-model<span> Button with using <a href="/@submit.prevent">@submit.prevent and Defining
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i67.tinypic.com/28ivy1l.png" srcset="https://images.hive.blog/768x0/http://i67.tinypic.com/28ivy1l.png 1x, https://images.hive.blog/1536x0/http://i67.tinypic.com/28ivy1l.png 2x" />
<p dir="auto">Firstly we used <code>@submit.prevent feature for <code>addTodo operation. We used <code>@submit.prevent instead of <code>@click because we will add something to do in our list. The <code>@click buttons a.k.a normal buttons <code>generally will direct us to another page. We want to add something to our list and we want to stay on the current page, so using the <code>@submit.prevent feature will let us stay on the page.<br />
And after creating <code>@submit.prevent button, we defined a division class for To-Do App input and after we created an input type as text with using <code>two way data binding and we defined class as form control because To-Do list is a kind of form.<br />
And after that we defined placeholder as <strong>Write something to do. This text will appear transparent and when we click on the textarea, this transparent text will disappear on the placeholder.<br />
Lastly we defined <code>v-model as <code>newTodo, we defined <code>v-model as an ID for script section, we will use this ID for <code>push mutation method. And another reason is, HTML input types aren't very helpful to us, so we want to make <strong>custom events with <strong>two way data binding feature by using input types. We can use <code>v-model to create custom inputs because <code>v-model can work with components. We will create To-Do List Application with helps of components.<br />
Finaly we created a submit button to <strong>add something to the list. We defined button class as "btn blue right" for blue button color<br />
After that we defined button type as <strong>submit because the task of this button is to <strong>add something to the list.
<h4>Creating <code>v-for Main Task with using <code>:key
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i65.tinypic.com/2m6stch.png" srcset="https://images.hive.blog/768x0/http://i65.tinypic.com/2m6stch.png 1x, https://images.hive.blog/1536x0/http://i65.tinypic.com/2m6stch.png 2x" />
<p dir="auto">We used <strong>ul class because todo list is a kind of list and we defined <strong>li class for <strong>todo-list item. We created this <strong>li class for <strong>todo list items.<br />
After that, we defined <code>v-for <strong>todo and <strong>index in todos.<br />
That means, <strong>todo indicates the <strong>tasks todo we will add.<br />
After that, we used <strong>index parameter, that means, when the any data is added to the list, this parameter will reflect the <strong>view of the newly added <strong>todo's to the page.<br />
Another reason <strong>why we define the index parameter? is, we will use the splice mutation method when adding the <strong>remove button. For this, we need to a <strong>referance for creating <strong>remove button scripts, so <code>index and todo parameters will help us for defining <strong>splice mutation method at the script section.<br />
Finally we defined <strong>todos. We can think of <strong>"todo, index in todos" section like <strong>"item and index in items". This is the <strong>v-for function's original form. We will add a few <strong>new todo's in our To-Do list so our <strong>new todo we will add will be in the our other todos, it will be in the <strong>To-Do List and it will be a <strong>To-Do List element.<br />
Firstly we used <code>v-for function with a component. As you know, when we use <code>v-for with a component, we need to use <code>:key in the same command line because it's the rule. And also we used <code>:key for <strong>todo-list items and we defined a simple data task with using <code>:key .
<p dir="auto">We have defined :key's main question as <strong>is-completed? That means <strong>is our work completed properly?. After that, we defined a kind of answer for this question as <strong>todo.completed. The key will affect "done" button directly with this dialogue. <strong>Dialogue: "If our work is completed properly, we will click the <strong>done button and <strong>To-Do List's Database will receive <strong>todo.completed as an answer.<br />
If the <strong>todo is successfully completed, the <code>:key will indicate that the work is done. But this operation will not appear on the page because Vue.js v2 supports <strong>Virtual DOM, <strong>Two-Way Data Binding and <strong>Computed Properties features.<br />
We have defined <code>v-for and <code>:key for <strong>completed tasks on the To-Do List.
<h4>Creating Field for To-Do List Elements
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i63.tinypic.com/2qwloip.png" srcset="https://images.hive.blog/768x0/http://i63.tinypic.com/2qwloip.png 1x, https://images.hive.blog/1536x0/http://i63.tinypic.com/2qwloip.png 2x" />
<p dir="auto">In this line, we created <strong>todo-container as division class and span class as <strong>todo-title. We want to add something to do into the To-Do List and we want the datas we add to appear under the To-Do List. And Reminder: All the <strong>things to do we will add to the list are <strong>data.<br />
We defined a container for create a field to the list elements we will add. And we also defined span class as <strong>todo-title because all the <strong>todo's we will add will be the <strong>title.<br />
Finally we defined <code>{{ todo.title }}, that means, all the data we will add to the list will be appended as <code>todo.title without any additions and only the tasks we have written will appear.
<h4>Defining <code>Done and <code>Remove Buttons Tasks (HTML)
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i63.tinypic.com/vpybo8.png" srcset="https://images.hive.blog/768x0/http://i63.tinypic.com/vpybo8.png 1x, https://images.hive.blog/1536x0/http://i63.tinypic.com/vpybo8.png 2x" />
<p dir="auto">In this line, we defined division class as <strong>actions-todo-list. We firstly defined the <strong>actions-todo-list as division class because we want to create two buttons, and these buttons will affect all of the list status.<br />
*<em>Done and <strong>Remove buttons will be in action and it will be the affect all of the list.<br />
Firstly, we defined <code>@click function as <code>todo.completed=true, we just defined <code>v-for :key as <code>todo.completed for completed tasks so we defined <code>@click function for done button with the help of the <code>v-for :key. We also defined <code>done buttons color as green and we defined <code>v-if function as <code>todo.completed. That means, "If we click on the <strong>done button, the system will assume that the to do has been completed." We talked about <code>v-if function but it works in much the same way as the <strong>if-else, which is the basic JavaScript functions, we learned <strong>if and else in other tutorials. We will talk about <code>v-if function in much more detail in other tutorial episodes because <strong>It's not just a function used with components.<br />
And finally we created the <strong>remove button to delete unfinished tasks. We defined <code>@click as <code>deleteTodo(index) this means, It will remove unfinished task from the <strong>view. The Remove button will affect the list element directly and will remove the list element from the list when the remove button is clicked.<br />
We will define the remove button in detail in the <strong>script section using the <strong>splice mutation method and <strong>index parameter. We also defined remove button's color as red.<br />
That's all of the To-Do List HTML codes.
<h4>Little CSS Editing for To-Do List
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i63.tinypic.com/e6skd0.png" srcset="https://images.hive.blog/768x0/http://i63.tinypic.com/e6skd0.png 1x, https://images.hive.blog/1536x0/http://i63.tinypic.com/e6skd0.png 2x" />
<p dir="auto">In the style tags, we defined <strong>maximum width value as <strong>800px, I used this value to make the To-Do List appear in the <strong>center of the page.<br />
And we also defined the <strong>margin value as <strong>auto because we want the <strong>gap between list and page to be set automatically. The gap will be calculated automatically by the browser.
<h4>Script Line: Creating new Vue Instance, Component and Data
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i63.tinypic.com/14t7xb7.png" srcset="https://images.hive.blog/768x0/http://i63.tinypic.com/14t7xb7.png 1x, https://images.hive.blog/1536x0/http://i63.tinypic.com/14t7xb7.png 2x" />
<p dir="auto">We defined new Vue Instance element with our main division id as usual. It's <strong>todoapp as you will understand. After that, we defined <strong>components as <strong>todoapp same as main divison id.<br />
And we also defined main data as <strong>function data, because <strong>data must be a function. This is the one of the important rules of Vue.js v2 (For Creating To-Do App). We need to use this feature only when creating applications like To-Do List. We are working with components so <strong>component’s data and main script values must be a function so any data entered into the list, it can maintain and list an independent copy of the returned data object.
<p dir="auto">After that, we defined <strong>newTodo value as blank. If we write something here, when we enter the page, the placeholder will be filled but we want the textarea to be empty because we will fill the list manually.<br />
And for the same reason, we haven't defined anything for <strong>todos, the same as <strong>newTodo, we will fill the <strong>todos field manually in the To-Do List.
<h4>Using Computed Properties for To-Do List
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i68.tinypic.com/2iltdu.png" srcset="https://images.hive.blog/768x0/http://i68.tinypic.com/2iltdu.png 1x, https://images.hive.blog/1536x0/http://i68.tinypic.com/2iltdu.png 2x" />
<p dir="auto">We need to use Computed Properties because, when we click on the <strong>done button for indicate that we approve the completed task, computed properties will show us the <strong>remove button that we have created after calculations in the background and It will allow us to remove the completed task from the list when we click on the <strong>remove button.<br />
And we also defined main computed value as <strong>completed function is completed. If you remember we just follow the <strong>data must be a function rule in the data script line.<br />
And our data returned <code>this.todos.todo. That means, Computed Properties are returning for any completed task in <strong>todos for all of the <strong>todo. We need to use computed properties feature because it will help us for <strong>completed tasks.
<h4>Creating Mutation Methods: <code>push
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i64.tinypic.com/rmqmwz.png" srcset="https://images.hive.blog/768x0/http://i64.tinypic.com/rmqmwz.png 1x, https://images.hive.blog/1536x0/http://i64.tinypic.com/rmqmwz.png 2x" />
<p dir="auto">Firstly we created <code>push mutation method for <strong>adding something to do list button, if<br />
And we just comply the <strong>addTodo must be a function rule and after that we created <code>push mutation, we defined it for add a new todo.<br />
And <code>this.todos.push this means, "any new <strong>todo that we add through the <strong>Add Something To Do button, <strong>new todo will be <code>pushed and created by the <code>push mutation method. With the help of <code>push method, we will be able to add a few <strong>new todos into the To-Do List. <code>this represents the <strong>addTodo button.<br />
And since we have established a connection between "<strong>addTodo and <strong>newTodo, these ID's represents <strong>todos to be newly created.<br />
After that, we defined <strong>title's task as <code>this.newTodo, that means, "Every todo we will create, will be accepted as a <strong>new todo and these <strong>todos will be listed under the previous todos".<br />
Every todo we will create will be assumed as a <strong>title.<br />
And we also defined completed status as <strong>false because we have used the <code>pushmethod to add <strong>new todos and we defined the <strong>status of new todos to be added as <strong>not completed because we will decide with the <strong>done button, whether the <strong>todo will be <strong>completed or <strong>not completed.<br />
We have defined <code>this.newTodo value as empty because we will add <strong>new todos to the list. If we fill this value, "when we enter the page the textarea appears as filled". We want to add <strong>todos manually to the list.
<h4>Creating Mutation Methods: <code>splice
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i68.tinypic.com/2hq9etv.png" srcset="https://images.hive.blog/768x0/http://i68.tinypic.com/2hq9etv.png 1x, https://images.hive.blog/1536x0/http://i68.tinypic.com/2hq9etv.png 2x" />
<p dir="auto">In the final step, we used <code>splice mutation method to define the properties of the <strong>remove button. We began by following the <strong>deleteTodo must be a function rule but unlike the others, we defined the <code>index parameter in parentheses. The reason of this, "when we remove a todo in our list, it will directly affect the <strong>index parameter and the <strong>list database."
<p dir="auto">We also defined <code>this.todos.splice(index,1), as you know <code>this we defined represents, "any <strong>newTodo we will add and "new todos" we will add will be <strong>together with our other todos in the list. The <code>splice method will <strong>trigger the <strong>remove button we have defined it to delete the <strong>todos and the <strong>added todos will be <strong>removed from the index with using <strong>remove button.
<p dir="auto">Since we need to reflect the operation to the <strong>index parameter, we have defined the index parameter into parentheses and defined the value as <strong>1 to trigger the splice mutation method.
<h3>Final State of Work
<p dir="auto"><img src="https://images.hive.blog/768x0/http://i63.tinypic.com/2m3fm21.png" srcset="https://images.hive.blog/768x0/http://i63.tinypic.com/2m3fm21.png 1x, https://images.hive.blog/1536x0/http://i63.tinypic.com/2m3fm21.png 2x" />
<h4>Video Tutorial
<p dir="auto">
<h4>Curriculum
<ul>
<li><a href="https://steemit.com/utopian-io/@sargoon/building-node-chart-with-using-vue-js-d3-network-and-materialize-css" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Building Node Chart with using Vue.js v2 D3-Network and Materialize CSS | Part #1
<h4>Proof of Work Done
<p dir="auto"><span><a href="https://github.com/sargoon" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/sargoon
Hi @sargoon,
This is a very good and thorough tutorial, well structured, with all the specific time noted for the learners to review. Excellent work.
You have developed a good style over the months. Only one advice in the presentation talk and that is, you can 'pause' a little bit after each concepts to give yourself and the learner a breather. This needs experience and I am sure as you do more video tutorial, you will learn this trick.
Your contribution has been evaluated according to Utopian policies and guidelines, as well as a predefined set of questions pertaining to the category.
To view those questions and the relevant answers related to your post, click here.
Chat with us on Discord.
[utopian-moderator]Need help? Write a ticket on https://support.utopian.io/.
Hi, Rosa. Thank you very much for your so valuable comment and also thank you for moderating my contribution. I'm glad you like my tutorial. And yes, you are absolutely right, I have to stop a bit while I'm explaining important concepts, I tried very hard to prevent the video from being too long but I will follow your advice on my next contributions.
Thanks for contributing on Utopian.
We’re already looking forward to your next contribution!Hey @sargoon
Want to chat? Join us on Discord https://discord.gg/h52nFrV.
Vote for Utopian Witness!