Elm এবং JavaScript এর মধ্যে ডেটা ট্রান্সফার

Ports এবং Interoperability (Elm এবং JavaScript এর মধ্যে সংযোগ) - এল্ম (Elm) - Computer Programming

187

Elm এবং JavaScript এর মধ্যে ডেটা ট্রান্সফার করার জন্য আপনি Elm JavaScript Interop ব্যবহার করতে পারেন। অর্থাৎ, Elm এবং JavaScript এর মধ্যে যোগাযোগ করার জন্য একটি ব্রিজ তৈরি করা হয়। Elm একটি কম্পাইলড ভাষা, যার মাধ্যমে আপনি JavaScript ফাংশন এবং মডিউল থেকে ডেটা গ্রহণ বা পাঠাতে পারেন এবং একইভাবে JavaScript থেকে Elm অ্যাপ্লিকেশনের ডেটা ব্যবহার করতে পারেন।

এখানে Elm এবং JavaScript এর মধ্যে ডেটা ট্রান্সফার করার জন্য কিছু সাধারণ কৌশল আলোচনা করা হলো:


১. Elm থেকে JavaScript এ ডেটা পাঠানো

Elm থেকে JavaScript এ ডেটা পাঠাতে ports ব্যবহার করা হয়। Ports হল Elm এবং JavaScript এর মধ্যে যোগাযোগের একটি নির্দিষ্ট পথ, যা একে অপরের সাথে ডেটা শেয়ার করতে সক্ষম করে।

উদাহরণ: Elm থেকে JavaScript এ ডেটা পাঠানো

ধরা যাক, আমরা Elm থেকে একটি স্ট্রিং JavaScript এ পাঠাতে চাই। প্রথমে Elm মডিউল তৈরি করতে হবে যেখানে ports ব্যবহার করা হবে।

Elm কোড:

port module Main exposing (..)

port sendData : String -> Cmd msg

update : Msg -> Model -> Model
update msg model =
    case msg of
        SendData data ->
            sendData data
            model

view : Model -> Html Msg
view model =
    div []
        [ button [ onClick (SendData "Hello from Elm!") ] [ text "Send Data to JavaScript" ]
        ]

init : Model
init = { }

main =
    Browser.element { init = init, update = update, view = view, subscriptions = always Sub.none }

এখানে, sendData পোর্ট ফাংশনটি Elm থেকে JavaScript এ একটি স্ট্রিং পাঠাবে।

JavaScript কোড:

var app = Elm.Main.init({
  node: document.getElementById('elm')
});

app.ports.sendData.subscribe(function(data) {
  console.log("Data from Elm: " + data);
});

এখানে, Elm অ্যাপটি sendData পোর্ট ব্যবহার করে JavaScript এ একটি স্ট্রিং পাঠাবে। JavaScript এ আমরা .subscribe() ফাংশন ব্যবহার করে এই ডেটা গ্রহণ এবং লগ করব।


২. JavaScript থেকে Elm এ ডেটা পাঠানো

JavaScript থেকে Elm এ ডেটা পাঠাতে, আমরা আবার ports ব্যবহার করি, তবে এবার JavaScript থেকে Elm পোর্টে ডেটা প্রেরণ করা হবে।

উদাহরণ: JavaScript থেকে Elm এ ডেটা পাঠানো

Elm কোড:

port module Main exposing (..)

port receiveData : (String -> msg) -> Cmd msg

update : Msg -> Model -> Model
update msg model =
    case msg of
        ReceiveData data ->
            -- Do something with data
            model

view : Model -> Html Msg
view model =
    div []
        [ text "Data received from JavaScript will be displayed here" ]

init : Model
init = { }

main =
    Browser.element { init = init, update = update, view = view, subscriptions = always Sub.none }

এখানে, receiveData পোর্ট ফাংশনটি Elm অ্যাপ্লিকেশনকে JavaScript থেকে ডেটা গ্রহণ করতে সহায়তা করবে।

JavaScript কোড:

var app = Elm.Main.init({
  node: document.getElementById('elm')
});

// Sending data to Elm
app.ports.receiveData.send("Hello from JavaScript!");

এখানে, JavaScript এর receiveData.send পোর্ট ফাংশন ব্যবহার করে Elm এ একটি স্ট্রিং পাঠানো হয়েছে। Elm অ্যাপ্লিকেশন সেই ডেটা গ্রহণ করবে এবং update ফাংশনে সেটি প্রক্রিয়া করবে।


৩. Complex Data Types এর সাথে পোর্ট ব্যবহৃত

Elm এবং JavaScript এর মধ্যে শুধু সাধারণ ডেটা নয়, আপনি complex data types যেমন objects, arrays, বা lists ইত্যাদি পোর্টের মাধ্যমে শেয়ার করতে পারেন।

উদাহরণ: Complex Data Types (Objects) পাঠানো

Elm কোড:

port module Main exposing (..)

port sendUserData : User -> Cmd msg

type alias User =
    { name : String
    , age : Int
    }

update : Msg -> Model -> Model
update msg model =
    case msg of
        SendUserData user ->
            sendUserData user
            model

view : Model -> Html Msg
view model =
    div []
        [ button [ onClick (SendUserData { name = "John", age = 30 }) ] [ text "Send User Data" ]
        ]

init : Model
init = { }

main =
    Browser.element { init = init, update = update, view = view, subscriptions = always Sub.none }

এখানে, sendUserData পোর্ট ব্যবহার করা হয়েছে, যা একটি User অবজেক্ট পাঠাবে যেখানে name এবং age থাকবে।

JavaScript কোড:

var app = Elm.Main.init({
  node: document.getElementById('elm')
});

app.ports.sendUserData.subscribe(function(user) {
  console.log("User Data from Elm:", user);
});

এখানে, JavaScriptElm থেকে পাঠানো User অবজেক্টে থাকা name এবং age প্রিন্ট করা হচ্ছে।


৪. Asynchronous Communication (অ্যাসিঙ্ক্রোনাস কমিউনিকেশন)

আপনি যদি Elm এবং JavaScript এর মধ্যে asynchronous communication করতে চান, যেমন API কল থেকে ডেটা গ্রহণ, তাহলে পোর্টের মাধ্যমে সেই ডেটা পাঠানো যেতে পারে।

উদাহরণ: JavaScript থেকে API ডেটা পাঠানো এবং Elm এ গ্রহণ করা

Elm কোড:

port module Main exposing (..)

port getApiData : (String -> msg) -> Cmd msg

update : Msg -> Model -> Model
update msg model =
    case msg of
        ApiDataReceived data -> { model | apiData = data }

view : Model -> Html Msg
view model =
    div []
        [ text model.apiData ]

init : Model
init = { apiData = "No data yet" }

main =
    Browser.element { init = init, update = update, view = view, subscriptions = always Sub.none }

JavaScript কোড:

var app = Elm.Main.init({
  node: document.getElementById('elm')
});

// Fetching data from API
fetch('https://api.example.com/data')
  .then(response => response.json())
  .then(data => {
    app.ports.getApiData.send(data);
  });

এখানে, JavaScript একটি API থেকে ডেটা পাচ্ছে এবং তা Elm এ পাঠাচ্ছে। Elm পোর্ট getApiData ব্যবহার করে সেই ডেটা গ্রহণ করবে এবং UI-তে প্রদর্শন করবে।


উপসংহার

Elm এবং JavaScript এর মধ্যে ডেটা ট্রান্সফার করার জন্য Ports একটি শক্তিশালী এবং কার্যকরী উপায়। Ports এর মাধ্যমে আপনি দুই ভাষার মধ্যে ডেটা পাঠাতে এবং গ্রহণ করতে পারেন, এবং এতে complex data types, asynchronous communication, এবং event-driven interaction ইত্যাদি সুবিধা থাকে। Elm এর পোর্ট সিস্টেম ব্যবহার করে আপনি ওয়েব অ্যাপ্লিকেশনগুলোর মধ্যে সঠিকভাবে তথ্য আদান-প্রদান করতে পারবেন।

Content added By
Promotion

Are you sure to start over?

Loading...