मेरे पास एक प्रतिक्रियाशील वेब एप्लिकेशन है जो ReactJS के साथ बनाया गया है जिसके लिए मैं एक दिन सर्वर-साइड प्रतिपादन का समर्थन करना चाहता हूं।सर्वर-साइड प्रतिपादन + उत्तरदायी डिजाइन + इनलाइन शैलियों -> जो उपयोग करने के लिए ब्रेकपॉइंट?
व्यूपोर्ट आकार के अनुसार, एप्लिकेशन लेआउट/व्यवहार में परिवर्तन। लेकिन इन सभी परिवर्तनों को न केवल सादा सीएसएस मीडियाक्वियर के साथ किया जा सकता है: जेएस व्यवहार, और अंतर्निहित एचटीएमएल संरचना भी चौड़ाई के अनुसार बदलना होगा।
उदाहरण के लिए मैं हो सकता है:
तहत 800px चौड़ाई:
<div class="app">
<div class="menu-mobile">...</div>
<div class="content">...</div>
<div class="mobile-left-menu">...</div>
<div class="footer-mobile">...</div>
</div>
ऊपर 800px चौड़ाई:
<div class="app">
<div class="menu">...</div>
<div class="main">
<div class="left-menu">...</div>
<div class="content">...</div>
<div class="right-menu">...</div>
</div>
<div class="footer">...</div>
</div>
अब, मैं सर्वर साइड प्रतिपादन उपयोग करना चाहते हैं उस आवेदन के लिए। लेकिन सर्वर पर मेरे पास चौड़ाई नहीं है, इसलिए मुझे नहीं पता कि कौन सी HTML संरचना क्लाइंट पर वापस आती है।
ध्यान दें कि मैं एक ऐसे समाधान की तलाश नहीं कर रहा हूं जो स्थिर डिफ़ॉल्ट सर्वर-साइड ब्रेकपॉइंट का उपयोग करे, और क्लाइंट पर ऐप को सही करे। मैं एक ऐसे समाधान की तलाश में हूं जो क्लाइंट को अपने डिवाइस के अनुसार उचित एचटीएमएल संरचना में वापस लाएगा। तो अगर वह अपने ब्राउज़र पर जावास्क्रिप्ट को अक्षम करता है तो उसे ठीक काम करना चाहिए।
यह तर्क हो सकता है कि मैं एचटीएमएल दोनों के लिए आवश्यक प्रस्तुत करना सकता है, और छिपाने/सादे सीएसएस mediaqueries और display: none
के साथ आवश्यक भागों दिखाने के लिए, लेकिन यह एप्लिकेशन पेचीदा और यह अप्रयुक्त HTML तत्वों का एक बहुत प्रस्तुत करना होगा क्योंकि आम तौर पर यह संभावना नहीं है कि उपयोगकर्ता ब्रेकपॉइंट के ऊपर/नीचे चलता है (मेरा मतलब है कि उसके पास मोबाइल डिवाइस है, डेस्कटॉप के लिए एचटीएमएल तत्वों का कभी भी उपयोग नहीं किया जाएगा)
इसके अलावा, अगर मैं इनलाइन-शैली का उपयोग करना चाहता हूं, तो यह बन जाता है जटिल क्योंकि मुझे सर्वर पर सही चौड़ाई के लिए इन इनलाइन शैलियों को प्रस्तुत करना होगा।
मेरे पास seen कुछ लोग ब्राउज़र व्यू को अपने व्यूपोर्ट आकार का अनुमान लगाने के अनुमान के बारे में सोच रहे हैं। लेकिन कुछ असुरक्षित स्क्रीन आयाम पहचान के साथ भी, मुझे यकीन नहीं है कि हम सर्वर-साइड पर डिवाइस स्क्रीन अभिविन्यास को जान सकते हैं।
क्या मैं इस समस्या को हल करने के लिए कुछ भी कर सकता हूं?
मुझे यकीन है कि यह आपके लिए पर्याप्त नहीं होगा, लेकिन आपको वास्तव में केवल दोनों डिस्प्ले प्रस्तुत करना चाहिए। जैसा कि आपने बताया है, आप वास्तव में क्लाइंट पर स्क्रीन आकार के बारे में सुनिश्चित नहीं हो सकते हैं, इसलिए आप यह नहीं जान पाएंगे कि आपको पूर्ण/मोबाइल संस्करण प्रस्तुत करना चाहिए या नहीं। यहां मैंने अपने ऐप में क्या किया है, हालांकि मुझे यकीन नहीं है कि यह एक अच्छा विचार है: मैंने अपने ऐप को उस घटक के साथ लपेट लिया जो एक आकार बदलने वाला श्रोता स्थापित करता है जो संदर्भ के माध्यम से दृश्य आकार साझा करेगा। प्रत्येक उत्तरदायी घटक दृश्य आकार को पढ़ेगा और तदनुसार प्रस्तुत करेगा। –
ग्राहक ऐप से प्रारंभिक अनुरोध में व्यूपोर्ट आकार, अभिविन्यास इत्यादि निर्दिष्ट करने के संदर्भ में आपकी सीमाएं क्या हैं? –
@LuisCrespo अपने प्रश्न को समझना सुनिश्चित नहीं है। मैं एसएसआर एटीएम नहीं कर रहा हूं और हल करने के लिए एक ठोस समस्या नहीं है, लेकिन मैं निकट भविष्य में एसएसआर का पता लगाने और इस तरह की समस्या को संभालने के बारे में जानना चाहता हूं। फिलहाल ऐसा लगता है कि गेर्शन पापी का सुझाव एकमात्र तरीका दुर्भाग्य से –