पर कस्टम तत्व बांधें मेरे आवेदन में मैंने बहुत सी "सेवाएं" बनाई हैं जिन्हें मैं अपने दृश्यमानों में कुछ अनावश्यकता और समय बचाने के लिए इंजेक्ट कर सकता हूं।ऑरेलिया कस्टम तत्वों में 2 तरीके डेटाबेसिंग - पैरेंट व्यूमोडल
अब मैं इसे 1 कदम आगे ले जाना चाहता हूं, और उन फॉर्म तत्वों (चयन, टेक्स्ट, चेकबॉक्स - स्टार्टर्स के लिए एक चुनिंदा ड्रॉपडाउन) बनाएं और उन्हें कस्टम तत्वों में बदल दें, केवल कस्टम तत्व में सेवा इंजेक्शन दें।
मैं इसे कुछ हद तक काम कर सकता हूं। कस्टम तत्व (इस मामले में चयन करें) दिखा रहा है जब मुझे इसे "पैरेंट" दृश्य में आवश्यकता होती है, हालांकि जब मैं कस्टम चयन तत्व का चयनित मान बदलता हूं, तो यह "पैरेंट" व्यूमोडेल से बंधे नहीं है, जो मेरी आवश्यकता है ।
मैं अपने चयनित मूल्य को कस्टम तत्व से "पैरेंट" व्यूमोडेल पर किसी संपत्ति में बाइंड में बाइंड विशेषता के माध्यम से बांधने में सक्षम होना चाहता हूं।
मैं कुछ मिनटों में एक छोटा सा कोड स्निपेट अपडेट करूंगा।
create.js (मैं क्या माता पिता viewmodel के रूप में उल्लेख)
import {bindable} from 'aurelia-framework';
export class Create{
heading = 'Create';
@bindable myCustomElementValue = 'initial value';
}
create.html (जनक दृश्य)
<template>
<require from="shared/my-custom-element"></require>
<my-custom selectedValue.bind="myCustomElementValue"></my-custom>
<p>The output of ${myCustomElementValue} should ideally be shown and changed here, as the select dropdown changes</p>
</template>
मेरी-custom.js
import { inject, bindable} from 'aurelia-framework';
import MyService from 'my-service';
@inject(MyService)
export class MyCustomCustomElement {
@bindable selectedValue;
constructor(myService) {
this.myService = myService ;
}
selectedValueChanged(value) {
alert(value);
this.selectedValue = value;
}
async attached() {
this.allSelectableValues = await this.myService.getAllValues();
}
}
क्या ऐसा होता है शुरुआत में create.html देखें "प्रारंभिक मान" आउटपुट, और जैसा कि मैं कस्टम तत्व का चयन बदलता हूं, नया चयनित मूल्य ई को सतर्क कर दिया जाता है, लेकिन यह बाध्य पैरेंट वैरिएबल को अपडेट नहीं करता है, जो अभी भी "प्रारंभिक मान" प्रदर्शित कर रहा है।
वाह धन्यवाद इतना:
त्वरित संदर्भ के लिए जाँच करने के लिए सबसे अच्छी जगहों में से एक डॉक्स में Aurelia धोखा पत्र है बहुत। क्या एक अद्भुत जवाब है। असल में सांप-केस चीज नमूना कोड में सिर्फ एक टाइपो थी, लेकिन दो-तरफा सभी अंतर थे! : डी क्या मैं आपसे पूछ सकता हूं कि आप क्या पसंद करते हैं - सजावटी या दो तरह से? – Dac0d3r
आपको डिफ़ॉल्ट बाध्यकारी मोड सेट करना चाहिए जो अन्य लोगों (या स्वयं) की अपेक्षा करता है। मैं कहूंगा कि इस उदाहरण में इसे डिफ़ॉल्ट रूप से दो-तरफा सेट करें क्योंकि यह आपके नियंत्रण का सबसे स्वाभाविक उपयोग है - आप लगभग हमेशा 'चयनित-मूल्य' को दो-तरफा बांधना चाहते हैं। इस तरह ऑरेलिया सम्मेलनों का उपयोग करता है और यह अच्छी तरह से काम करता है। – Charleh
+1 और सांप-आवरण के लिए धन्यवाद। मैंने दस्तावेज़ों में वर्णित नहीं देखा क्योंकि उदाहरण एक शब्द चर थे। एक बाध्यकारी को समझने की कोशिश कर पागल हो जाना काम नहीं किया गया था जब यह सिर्फ दूसरों के समान ही किया गया था। – Danomite