ভুজেএস

উইকিপিডিয়া, মুক্ত বিশ্বকোষ থেকে
পরিভ্রমণে ঝাঁপ দিন অনুসন্ধানে ঝাঁপ দিন
Vue.js
Vue.js Logo 2.svg
মূল উদ্ভাবকইভান ইউ
প্রাথমিক সংস্করণফেব্রুয়ারি ২০১৪; ৬ বছর আগে (2014-02)[১]
স্থায়ী মুক্তি2.6.10 / ২০ মার্চ ২০১৯; ১৬ মাস আগে (2019-03-20)[২]
লেখা হয়েছেJavaScript
আকার30.67 KB production
279 KB development
ধরণJavaScript framework
লাইসেন্সMIT License[৩]
ওয়েবসাইটvuejs.org

Vue.js (সাধারণভাবে ভু ; উচ্চারিত /vj/ , মত মত ) হচ্ছে একটা মডেল-ভিউ-ভিউমডেল শৈলীর উন্মুক্ত-উৎসের সফটওয়্যার যা সাধারনত ইন্টারএক্টিভ ওয়েব এপলিকেশন তৈরির জন্য ব্যাবহার করা হয়ে থাকে । ভ্যু ইউজার ইন্টারফেস তৈরির জন্য একটি প্রগতিশীল কাঠামো। এবং যা সিংগেল পেজ এপ্লিকেশন তৈরির জন্য ব্যাবহার করা হয়ে থাকে [৪] ভূ-জেস একটি অঙ্গুলার-জেস সমধর্মী স্ক্রিপ্টিং ভাষা। ভ্যূ মূলধারা থেকে ক্রমবর্ধমান গ্রহণযোগ্য হতে ডিজাইন করা হয়েছে।

ইতিহাস[সম্পাদনা]

ভু তৈরি করেছেন ইভান ইউ । যিনি এর আগে গুগল এর প্রডাক্ট এংগুলার যে এস ডেভেলপমেন্ট এ কাজ করেছেন । তিনি পরে তার চিন্তাধারার প্রক্রিয়াটি সংক্ষেপে তুলে ধরেন: "আমি মনে করি, আমি যদি এমন অংশটি বের করতে পারি যা কিনা সত্যি এংগুলার এর চাইতে হালকা হবে । " [৫] ভু মূলত ২০১৪ সালের ফেব্রুয়ারি মাসে মুক্তি পায়।

বিবরণ[সম্পাদনা]

Vue.js একটি ক্রমবর্ধমানভাবে গ্রহণযোগ্য আর্কিটেকচার বৈশিষ্ট্য সমৃদ্ধ এবং যা রেন্ডারিং এবং কম্পনেন্ট বেজ কাজ করে । কোন ফাংশানের এডভান্সড ফিচারের প্রয়োগের জন্য এর রাউটিং , স্টেট ম্যানেজমেন্ট এবং বিল্ড টুলিংয়ের এর ব্যাবহার শুনিসচিত করতে হবে যাতে সহায়তাকারী লাইব্রেরি এবং প্যাকেজগুলির অন্তুর্ভুক্তি থাকবে । [৬]

মডেল-ভিউ-ভিউমডেল শৈলীর অন্তর্ভুক্ত হওয়ায় এর গঠনকে ৩ ভাগে ভাগ করা যায় :

মডেল[সম্পাদনা]

স্ক্রিপ্ট ট্যাগের মধ্যবর্তি এই অংশে পশ্চাদপ্রান্তের পরিষেবা থেকে তথ্য কোনো অবজেক্টে অর্পণ করা হয়।

1     data(){   
2         return{
3             testdata : "Hello",
4         }
5     },

ভিউমডেল[সম্পাদনা]

এটির অবস্থান মূল জাভাস্ক্রিপ্ট ফাইলে(main.js) যা প্রারম্ভিক ফাইল গুলোর একটি। এটি মূলত একটি ভিত্তি যার ওপর মডেল ও ভিউ তাদের কার্যক্রম করে এবং নিজেদের মধ্যে সমন্বয় সাধন করে।

1  new Vue({
2    el : "#app",
3  data : data 
4  })

ভিউ[সম্পাদনা]

এটি প্রান্তিক অংশ যেটা ব্যাবহারকারীদের প্রতি উন্মুক্ত হয়।

1 <template>
2  <div id="app">
3    {{testdata}}
4  </div>
5  </template>

বৈশিষ্ট্য[সম্পাদনা]

Vue ব্যবহারকারীরা ভু এর টেমপ্লেট সিস্টেম ইউজ করে কোড লিখতে পারেন বা JSX ব্যবহার করে সরাসরি রেন্ডার ফাংশন লিখতে পারেন । [৭] ভু এ ডাটা রেন্ডারিং পুরোটা কম্পোনেন্ট বেজ । । [৮]

রিঅ্যাকটিবিটি[সম্পাদনা]

Vue একটি প্রতিক্রিয়াশীলতা সিস্টেম যা প্লেইন জাভাস্ক্রিপ্ট অবজেক্ট এবং অপটিমাজিং রি-রেন্ডার ব্যাবহার করে । প্রতিটি উপাদান তার রেন্ডারিংয়ের সময় তার ডিপেন্ডেন্সির উপরে খেয়াল রাখে , তাই সিস্টেম বুঝতে পারে কখন রি এবং কোন এলিমেন্ট রি রেন্ডার হচ্ছে [৯]

উপাদান[সম্পাদনা]

 1 <div id="tuto">
 2 	<button-clicked v-bind:initial-count="0"></button-clicked>
 3 </div>
 4 
 5 <script>
 6 Vue.component('button-clicked', {
 7   props: [ "initialCount" ],
 8   data: () => ({
 9     count: 0,
10   }),
11   template: `<button v-on:click="onClick">Clicked <nowiki>{{ count }}</nowiki> times</button>`,
12   computed: {
13     countTimesTwo() {
14       return this.count * 2;
15     }
16   }
17   watch: {
18     count(newValue, oldValue) {
19       console.log(`The value of count is changed from ${oldValue} to ${newValue}.`);
20     }
21   }
22   methods: {
23     onClick() {
24         this.count += 1;
25     }
26   },
27   mounted() {
28     this.count = this.initialCount;
29   }
30 });
31 
32 new Vue({
33   el: '#tuto',
34 });
35 </script>

রাউটিং[সম্পাদনা]

 1 <div id="app">
 2   <router-view></router-view>
 3 </div>
 4 ...
 5 
 6 <script>
 7 ...
 8 const User = {
 9   template: '<div>User <nowiki>{{ $route.params.id }}</nowiki></div>'
10 }
11 
12 const router = new VueRouter({
13   routes: [
14     { path: '/user/:id', component: User }
15   ]
16 })
17 ...
18 </script>

ভূ-জেস রাউটিং পরিষেবা প্রদান করে।

উপরের কোডটি:

  1. websitename.com/user/<id> এ একটি ফ্রন্ট-এন্ড রাউট সেট করে।
  2. যা রেন্ডার হবে (কনস্টেবল ব্যবহারকারী। । । )
  3. ব্যবহারকারীর নির্দিষ্ট উপাদানটি পাস করার জন্য ব্যবহারকারীর উপাদানকে অনুমতি দেয় যা $ রুট অবজেক্টের $route.params.id কী ব্যবহার করে URL এ টাইপ করা হয়েছিল: $route.params.id
  4. ডম এর এলেমেন্ট গুলা এর মধ্যে <router-view></router-view> রেন্ডার করা হবে।
  5. অবশেষে জেনারেট করা HTML আউটপুট ফাইল : websitename.com/user/1


1 <div id="app">
2   <div>
3     <div>User 1</div>
4   </div>
5 </div>

[১০]

পরিকাঠামো গঠন[সম্পাদনা]

স্ক্রিপ্ট ট্যাগ ব্যাবহার করে[সম্পাদনা]

এটি সহজতম পদ্ধতি। এক্ষেত্রে ভূ এর ওয়েবসাইট vuejs.org/v2/guide/installation.html থেকে তার জাভাস্ক্রিপ্ট ফাইলটি ডাউনলোড করা এবং সেটি সরাসরি ব্যবহার করা।

এক্ষেত্রে ২ রকম জাভাস্ক্রিপ্ট ফাইল রয়েছে। একটি ডেভেলপমেন্ট সংস্করণ vue.js এবং অন্যটি প্রোডাকশন সংস্করণ(সিঞ্চিত সংস্করণ) vue.min.js

নিচে একটি নমুনা দেয়া হলো :

1 <html>
2    <head>
3       <script type = "text/javascript" src = "vue.min.js"></script>
4    </head>
5    <body></body>
6 </html>

কমান্ড-লাইন ইন্টারফেস ব্যবহার করে[সম্পাদনা]

পূর্ব-প্রয়োজনীয় হিসাবে নোড প্যাকেজ ম্যানেজার ইনস্টল করতে হবে। যদি তা থাকে তবে , প্রথমে CLI ইনস্টল করতে :

npm install --global vue-cli

ওয়েবপ্যাক মডিউল বান্ডলার ব্যবহার করে প্রজেক্ট শুরু করা

vue init webpack <project name>

পরবর্তী অপশনগুলো সিলেক্ট করে নেয়া। স্ক্রিন এ প্রজেক্ট সফল তৈরির মেসেজ থাকবে।

এবার প্রজেক্ট টি চালাতে হলে , প্রথমে সেই প্রজেক্ট লোকেশন অব্দি যেতে হবে। তারপর নিম্নোক্ত কম্যান্ড চালাতে হবে :

npm run dev

যদি প্রজেক্টটি ইতিমধ্যেই তৈরী অবস্থায় থাকে তবে চালাতে হলে , প্রথমে সেই প্রজেক্ট লোকেশন অব্দি যেতে হবে। তারপর নিম্নোক্ত কম্যান্ড চালাতে হবে :

npm run serve

এইচটিটিপি গ্রাহক সংযোগ[সম্পাদনা]

ওয়েবে অ্যাপ্লিকেশন তৈরি করার সময় অনেক সময় কোনও এপিআই থেকে ডেটা গ্রাস করতে এবং প্রদর্শন করতে চাইতে হতে পারে। এটি করার বেশ কয়েকটি উপায় রয়েছে তবে খুব জনপ্রিয় পদ্ধতির মধ্যে রয়েছে এক্সিওস , যা একটি প্রতিশ্রুতি ভিত্তিক এইচটিটিপি গ্রাহক ।

এক্সিওস ইনস্টল করতে

npm install axios—save

একটি জাভাস্ক্রিপ্ট (.js) ফাইল তৈরী করতে হবে। ধরাযাক সেটি তৈরী হলো ../../js/apis/ স্থানে। নাম backend-apis.js

তাতে একটি get অনুরোধ করতে হলে নিম্নরূপ কোড হবে :[১১]

import axios from 'axios'
export default{
    getCustomers(phoneNumber){
        return axios.get('http://localhost:8111/callcenter/api/customerService/phone/' + phoneNumber,{timeout:5000});
    },
}

এবার যে ভূ ফাইলে থেকে অনুরোধটি সূচিত হবে তার মডেলের মধ্যে (স্ক্রিপ্ট ট্যাগ এর মধ্যে)

import api  from '../../js/apis/backend-apis'
export default {
    data(){   
        return{
            searchPanelResponse: {}
        }
    },
    methods:
    {       
        getCustomers(phoneNo){
            if (phoneNo !== null && phoneNo !== undefined && phoneNo !== '') {
                api.getCustomers(phoneNo).then(
                response => {
                    this.searchPanelResponse = {
                        showCustList : true,
                        backEndResponse : response.data,
                        errors : {}
                    }
                    this.$store.commit('updateCustList', this.searchPanelResponse);
                    }).catch(error=>{
                        //error handling goes here                                       
                    })   
            }              
        }
    },   
}

আরো দেখুন[সম্পাদনা]

  • জাভাস্ক্রিপ্ট ফ্রেমওয়ার্ক তুলনা
  • প্রতিক্রিয়া
  • AngularJS
  • কৌণিক
  • জাভাস্ক্রিপ্ট ফ্রেমওয়ার্ক
  • Javascript লাইব্রেরি

তথ্যসূত্র[সম্পাদনা]

  1. "First Week of Launching Vue.js"Evan You 
  2. "Vue.js Releases"GitHub 
  3. "vue/LICENSE"GitHub। সংগ্রহের তারিখ ১৭ এপ্রিল ২০১৭ 
  4. "Introduction — Vue.js" (ইংরেজি ভাষায়)। সংগ্রহের তারিখ ২০১৭-০৩-১১ 
  5. "Between the Wires | Evan You"Between the Wires। ২০১৬-১১-০৩। ২০১৭-০৬-০৩ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ ২০১৭-০৮-২৬ 
  6. "Evan is creating Vue.js | Patreon"Patreon (ইংরেজি ভাষায়)। সংগ্রহের তারিখ ২০১৭-০৩-১১ 
  7. "Template Syntax — Vue.js" (ইংরেজি ভাষায়)। সংগ্রহের তারিখ ২০১৭-০৩-১১ 
  8. "Vue 2.0 is Here!"The Vue Point। ২০১৬-০৯-৩০। সংগ্রহের তারিখ ২০১৭-০৩-১১ 
  9. "Reactivity in Depth — Vue.js" (ইংরেজি ভাষায়)। সংগ্রহের তারিখ ২০১৭-০৩-১১ 
  10. You, Evan। "Vue Nested Routing (2)"Vue Home Page (subpage)। সংগ্রহের তারিখ ১০ মে ২০১৭ 
  11. "Axios Cheat Sheet" 

বাহ্যিক লিঙ্ক[সম্পাদনা]