<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>events &#8211; The SIGMA</title>
	<atom:link href="https://danushka96.github.io/sigma/index.php/tag/events/feed/" rel="self" type="application/rss+xml" />
	<link>https://danushka96.github.io/sigma/</link>
	<description>&#60;For Those Who Code/&#62;</description>
	<lastBuildDate>
	Sat, 02 Mar 2019 16:57:34 +0000	</lastBuildDate>
	<language>en-US</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=5.1.1</generator>
	<item>
		<title>VueJs 2 &#8211; 04 Event එක්ක වැඩ කරමු</title>
		<link>https://danushka96.github.io/sigma/index.php/2018/04/14/vuejs-2-04/</link>
				<comments>https://danushka96.github.io/sigma/index.php/2018/04/14/vuejs-2-04/#comments</comments>
				<pubDate>Sat, 14 Apr 2018 15:17:34 +0000</pubDate>
		<dc:creator><![CDATA[Prasad Kavinda]]></dc:creator>
				<category><![CDATA[VueJs]]></category>
		<category><![CDATA[web development]]></category>
		<category><![CDATA[events]]></category>
		<category><![CDATA[Vue]]></category>

		<guid isPermaLink="false">https://danushka96.github.io/sigma/?p=740</guid>
				<description><![CDATA[<p><span class="rt-reading-time" style="display: block;"><span class="rt-label">Reading Time: </span> <span class="rt-time">4</span> <span class="rt-label rt-postfix">minutes</span></span> හැමෝටම එසේම වේවා 😀 ! Vue ගැන ලියන 4 වෙනි post එක. කලින් post එකේදි අපි Vue directives ගැන කතා කරානෙ. ඒකෙදි කිව්ව වගේම අද කියන්න යන්නෙ Vue වලින් events handle කරන්නෙ කොහොමද කියල. මං හිතනව ඔයාල events කියන්නෙ මොනවද කියල දන්නව ඇති කියල. mouse click, drag, keyup, keydown ඔය<a class="moretag" href="https://danushka96.github.io/sigma/index.php/2018/04/14/vuejs-2-04/"> Read more&#8230;</a></p>
<p>The post <a rel="nofollow" href="https://danushka96.github.io/sigma/index.php/2018/04/14/vuejs-2-04/">VueJs 2 &#8211; 04 Event එක්ක වැඩ කරමු</a> appeared first on <a rel="nofollow" href="https://danushka96.github.io/sigma/">The SIGMA</a>.</p>
]]></description>
								<content:encoded><![CDATA[<span class="rt-reading-time" style="display: block;"><span class="rt-label">Reading Time: </span> <span class="rt-time">4</span> <span class="rt-label rt-postfix">minutes</span></span><p>හැමෝටම එසේම වේවා 😀 ! Vue ගැන ලියන 4 වෙනි post එක. <a href="https://danushka96.github.io/sigma/index.php/2018/04/12/vuejs-2-03/" target="blank">කලින් post එකේ</a>දි අපි Vue directives ගැන කතා කරානෙ. ඒකෙදි කිව්ව වගේම අද කියන්න යන්නෙ Vue වලින් events handle කරන්නෙ කොහොමද කියල. මං හිතනව ඔයාල events කියන්නෙ මොනවද කියල දන්නව ඇති කියල. mouse click, drag, keyup, keydown ඔය වගේ ඒවනෙ. (ඒ වගේම අපිට custom event උනත් හදන්න පුළුවන්නෙ) මේ events වලට event listeners set කරන්න v-on කියන directive එක භාවිතා කරනව. v-on එකට මේ වගේ syntax එකක් තමයි තියෙන්නෙ.</p>
<blockquote><p>v-on:<strong>event</strong>=&#8221;<strong>expression or method</strong>&#8220;</p></blockquote>
<p>මේකෙ event කියන්නෙ අපි listen කරන event එක.(click, keyup, keydown, submit වගේ) ඒකට value එක විදියට දෙන්න ඕනෙ, ඒ event එක trigger උනාම වෙන්න ඕනෙ මොකද්ද කියල. ඒකට ඕන නම් එතනම expression එකක් ලියන්නත් පුළුවන් නැත්තම් (methods object එකේ) define කරපු method එකක් දෙන්න පුළුවන්. අපි උදාහරණයකින් බලමු කොහොමද මේක කරන්නෙ කියල.</p>
<p>මගේ data object එකේ තියෙන age කියන අගය button එකක් click කරද්දි එකකින් වැඩි වෙන්න ඕනෙ කියල හිතමු.</p>
<pre>data: {
    age: 25
}</pre>
<pre>&lt;div id="my-app"&gt;
    &lt;h1&gt; My age is {{ age }}&lt;/h1&gt;
    &lt;button v-on:click="age++"&gt;+&lt;/button&gt;
&lt;/div&gt; 
</pre>
<p>මෙන්න මේ විදියට ඔයාලට පුළුවන් v-on directive එක පාවිචිච කරල button එකට click event listener එකක් set කරන්න. එතකොට ඒ button එක click කරද්දි  age++ කියන code එක run වෙනව. එතකොට age කියන data එක, එකකින් increment වෙනව. h1 tag එකෙන් ඒක වෙනස් වෙනව බලාගන්න පුළුවන්.</p>
<p>මේ විදියටම ඔයාලට පුළුවන් button එක click කරද්දි method එකක් call කරන්න. මේ වගේ,</p>
<pre>data: {
    age: 25
},
methods: {
    inc_age: function (i) {
        this.age += i
    }
}
</pre>
<pre>&lt;div id="my-app"&gt;
    &lt;h1&gt; My age is {{ age }}&lt;/h1&gt;
    &lt;button v-on:click="inc_age(2)"&gt;+&lt;/button&gt;
&lt;/div&gt;</pre>
<p>මේ විදියට ඔයාලට කැමති event එකකට (custom event උනත්) listen කරන්න පුළුවන්.</p>
<h4><strong>event modifier</strong></h4>
<p>v-on directive එකෙන් event listener set කරද්දි, ඒව එක එක විදියට modify කරන්න පුළුුවන්. හිතන්නකො මේ කලින් උදාහරණයෙ button click event එකම. ඒ event එක එක පාරක් විතරක් listen කරන්න ඕනෙ නම් (ඒ කියන්නෙ පළවෙනි click එකෙන් පස්සෙ එ් listener එක වැඩ කරන්නෙ නැතිවෙන්න නම්) once කියන modifier එක පාවිච්චි කරන්න පුළුවන්. මේ විදියට.</p>
<pre>v-on:click.once="inc_age(2)"</pre>
<p>form එකක් submit කරන අවස්ථාවක් ගමුකො තව උදාහරණයකට. normal විදියට form එක submit කරද්දි form එකේ data ටික, post වෙලා, page එක reload වෙන එකනෙ වෙන්නෙ. හැබැයි අපි SPA එකක් වගේ හදනවනම්, (මම පළවෙනි post එකේ කිව්ව වගේ) අපි page reload කරන්නෙ නෑ. ඒ වෙනුවට අපි කරන්නෙ, form එක submit කරද්දි, AJAX request එකකින් මේ data ටික back-end එකට post කරන එක. අපි හිතමුකො ඒ post කරන එකට අදාල code එක, onSubmit කියල method එකක අපි ලිව්ව කියල. එතකොට form එක මේ වගේ තියෙයි.</p>
<pre>&lt;div id="my-app"&gt;

    &lt;form v-on:submit="onSubmit"&gt;
        Name: &lt;input type="text" v-model="name"&gt;
        &lt;button type="submit"&gt;Submit&lt;/button
    &lt;/form&gt;
&lt;/div&gt;
</pre>
<blockquote><p>app.js</p></blockquote>
<pre>const app = new Vue({
    el: '#my-app',
    data: {
        name: 'John Doe'
    },
    methods: {
    	onSubmit: function () {
    	    alert(this.name);
    	}
    }
});
</pre>
<p>මම මතෙනදි නිකංම name එක alert කරන එක විතරයි කරන්නෙ. (ඉදිරි post එකකින් බලමු, කොහොමද AJAX request handle කරන්නෙ කියල) දැන් මේ submit button එක click කරොත් name එක alert වෙනව පෙනේවි. හැබැයි ඒක OK කරාට පස්සෙ, page එක reload වෙනව ඔයාලට බලාගන්න පුළුවන් වෙයි. ඒකට හේතුව, submit button එකේ default action එක. අපි ඒක නවත්තන්න ඕනෙ. <strong>.prevent</strong> modifier එකෙන් ඒක කරන්න පුළුවන්.</p>
<pre>v-on:submit.prevent="onSubmit"
</pre>
<p>මේ විදියට වෙනස් කරාම page එක reload වෙන්නෙ නෑ කියල ඔයාලට පෙනෙයි. 😀</p>
<p>තව දෙයක් කියන්න ඕනෙ මේ එක්කම. මේ උදාහරණයෙදි ඔයාලට පේනව ඇති text field එකේ තියෙන value මම අරගත්තු විදිය. සාමාන්‍යන් JQuery වගේ යොදාගෙන text field එකේ value එක save කරගන්න නම්, ඉස්සෙල්ලම DOM එක search කරල මේ text field එක හොයා ගන්න ඕනෙ. ඊට පස්සෙ තමයි ඒකෙ value එක අරගන්නෙ. හැබැයි Vue වලින් අපිට පහසුවෙන්ම 2 way විදියට data bind කරන්න පුලුවන් නිසා, සෑහෙන්න ලේසියෙන් value එක ගන්න පුළුවන්. කරන්න තියෙන්නෙ v-model directive එක පාවිච්චි කරන්න විතරයි. එතකොට text field එකේ type කරන දේ ඒ මොහොතෙදිම name කියන data එකේ save වෙනව.</p>
<h4><strong>key modifier</strong></h4>
<p>මේ උදාහරණය බලන්නකො. මට ඕනෙ මේ text field එකේ type කරන එක, Enter key එක එබුවම browser console එකේ print කරන්න. (console එක ගැන පළවෙනි post එකේ කිව්ව මතක ඇති)</p>
<pre>&lt;div id="my-app"&gt;
    Name: &lt;input type="text" v-model="name"&gt;
&lt;/div&gt;
</pre>
<p>මේ වැඩේ කරගන්න අපිට keyDown event එකට <strong>.enter </strong>කියන key modifier එක පාවිච්චි කරන්න පුළුවන්. මේ විදියට,</p>
<pre>&lt;div id="my-app"&gt;
    Name: &lt;input type="text" v-model="name" v-on:keyDown.enter="logMessage"&gt;
&lt;/div&gt;
</pre>
<blockquote><p>app.js</p></blockquote>
<pre>const app = new Vue({
    el: '#my-app',
    data: {
    	name: 'John Doe',
    },
    methods: {
    	logMessage: function () {
    	    alert(this.name);
    	    this.name = '';
    	}
    }
});
</pre>
<p>මේක run කරල බැලුවම මේ වගේ console එකේ print වෙනව බලා ගන්න පුළුවන්.</p>
<p><img class="wp-image-835 aligncenter" src="https://danushka96.github.io/sigma/wp-content/uploads/2018/04/keymodifier-300x191.png" alt="key modifier example output" width="674" height="429" srcset="https://danushka96.github.io/sigma/wp-content/uploads/2018/04/keymodifier-300x191.png 300w, https://danushka96.github.io/sigma/wp-content/uploads/2018/04/keymodifier-768x489.png 768w, https://danushka96.github.io/sigma/wp-content/uploads/2018/04/keymodifier-1024x651.png 1024w, https://danushka96.github.io/sigma/wp-content/uploads/2018/04/keymodifier.png 1226w" sizes="(max-width: 674px) 100vw, 674px" /></p>
<p>v-model භාවිතා කිරීමේ තවත් වාසියක් මෙතනදි බලාගන්න පුළුවන්. logMessage method එකේ 2වනි පේළියෙදි name=&#8221; කියල දීල තියෙනව. මේකෙන් වෙන්නෙ, <kbd>enter</kbd> key එක ඔබන හැම වතාවකදිම, input field එක clear කරන එක. මොකද, (කලින් post එකේ කිව්ව වගේ) data වලට වෙන වෙනස්වීම් දිහා Vue වලින් බලාගෙන ඉන්න නිසා, ඒ data වෙනස් වෙද්දි, ඒ data bind වෙලා තියෙන හැම තැනමත්, ඒ විදියටම වෙනස් වෙනව.</p>
<p>තව දෙයක් තියෙනව. අපිට ඕනෙ නම් key combination එකක් (<kbd>alt</kbd>+<kbd>enter</kbd>, <kbd>shift</kbd>+<kbd>enter</kbd> වගේ) උනත් යොදන්න පුළුවන්. <kbd>Alt</kbd>+<kbd>Enter</kbd> key combination එක පාවිච්චි කරන්නම් <strong>.alt</strong> modifier එක පාවිච්චි කරන්නයි තියෙන්නෙ.</p>
<pre>v-on:keyDown.alt.enter="logMessage"
</pre>
<p>මේ විදියට <strong>.shift .ctrl </strong>වගේ key උනත් භාවිතා කරන්න පුළුවන්.</p>
<blockquote><p>v-on directive එක පාවිච්චි කරද්දි හැමතිස්සෙම v-on, v-on කියල ලියන එක කරදරයක් නම්, ඔයාලට පුළුවන් ඒ වෙනුවට <strong>@</strong> symbol එක භාවිතා කරන්නත්. මේ වගේ,</p>
<pre>@click="some_method"
</pre>
</blockquote>
<p>මේවගේ modifier වර්ග තව තියෙනව. මේවයෙ තවත් විස්තර ඔයාලට <a href="https://vuejs.org/v2/guide/events.html" target="blank">VueJs.org</a> එකෙන් බලන්න පුළුවන්. මම අදට මෙතනින් නවත්තන්නම්. ඊළඟ post එකෙන් හමුවෙමු. අදහස්, යෝජනා, ඡෝදනා, ප්‍රශ්න මොනවහරි තියෙනම් comment එකක් දාන්න. 😀</p>
<p>ඊළඟ post එකට <a href="https://danushka96.github.io/sigma/index.php/2018/04/20/vuejs-2-05/">මෙතනින්</a> යන්න.</p>
<p>The post <a rel="nofollow" href="https://danushka96.github.io/sigma/index.php/2018/04/14/vuejs-2-04/">VueJs 2 &#8211; 04 Event එක්ක වැඩ කරමු</a> appeared first on <a rel="nofollow" href="https://danushka96.github.io/sigma/">The SIGMA</a>.</p>
]]></content:encoded>
							<wfw:commentRss>https://danushka96.github.io/sigma/index.php/2018/04/14/vuejs-2-04/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
							</item>
	</channel>
</rss>
