मैं PHP से जावास्क्रिप्ट में चर और डेटा कैसे पास कर सकता हूं?


664

मेरे पास PHP में एक चर है, और मुझे अपने जावास्क्रिप्ट कोड में इसके मूल्य की आवश्यकता है। मैं PHP से जावास्क्रिप्ट में अपना चर कैसे प्राप्त कर सकता हूं?

मेरे पास कोड है जो इस तरह दिखता है:

<?php
     ...
     $val = $myService->getValue(); // Makes an API and database call
?>

मेरे पास जावास्क्रिप्ट कोड है जिसकी आवश्यकता है valऔर इसकी तर्ज पर दिखता है:

<script>
    myPlugin.start($val); // I tried this, but it didn't work
    <?php myPlugin.start($val); ?> // This didn't work either
    myPlugin.start(<?=$val?> // This works sometimes, but sometimes it fails
</script>

2
क्या myPlugin.start(<?=$val?>जानबूझकर लापता क्लोजिंग कोष्ठक था ? क्या यह सच है कि "यह कभी-कभी काम करता है"?
एंड्रयू

2
वैसे यह वास्तव में बेन द्वारा किया गया था, लेकिन चलो बस यह कहेंगे कि यदि $ वैल है तो "42)"यह अच्छी तरह से काम करेगा: डी
मदारा का भूत

जवाबों:


877

ऐसा करने के लिए वास्तव में कई दृष्टिकोण हैं। कुछ को दूसरों की तुलना में अधिक ओवरहेड की आवश्यकता होती है, और कुछ को दूसरों की तुलना में बेहतर माना जाता है।

किसी विशेष क्रम में नहीं:

  1. सर्वर से अपनी जरूरत का डेटा प्राप्त करने के लिए AJAX का उपयोग करें।
  2. कहीं पेज में डेटा इको, और डोम से जानकारी प्राप्त करने के लिए जावास्क्रिप्ट का उपयोग करें।
  3. डेटा को सीधे जावास्क्रिप्ट पर इको करें।

इस पोस्ट में, हम उपरोक्त विधियों में से प्रत्येक की जांच करेंगे, और प्रत्येक के पेशेवरों और विपक्षों को देखेंगे, साथ ही उन्हें कैसे लागू करेंगे।

1. सर्वर से आपको आवश्यक डेटा प्राप्त करने के लिए AJAX का उपयोग करें

इस विधि को सबसे अच्छा माना जाता है, क्योंकि आपके सर्वर साइड और क्लाइंट साइड स्क्रिप्ट पूरी तरह से अलग हैं

पेशेवरों

  • परतों के बीच बेहतर जुदाई - यदि कल आप PHP का उपयोग करना बंद कर देते हैं, और एक सर्वलेट, एक REST API, या कुछ अन्य सेवा में जाना चाहते हैं, तो आपको जावास्क्रिप्ट कोड में ज्यादा बदलाव नहीं करना पड़ेगा।
  • अधिक पठनीय - जावास्क्रिप्ट जावास्क्रिप्ट है, PHP PHP है। दोनों को मिलाए बिना, आपको दोनों भाषाओं पर अधिक पठनीय कोड मिलता है।
  • अतुल्यकालिक डेटा स्थानांतरण की अनुमति देता है - PHP से जानकारी प्राप्त करना समय / संसाधन महंगा हो सकता है। कभी-कभी आप केवल जानकारी के लिए इंतजार नहीं करना चाहते हैं, पेज लोड करते हैं, और जब भी सूचना पहुंचते हैं।
  • मार्कअप पर डेटा सीधे नहीं मिलता है - इसका मतलब है कि आपके मार्कअप को किसी भी अतिरिक्त डेटा से साफ रखा गया है, और केवल जावास्क्रिप्ट इसे देखता है।

विपक्ष

  • विलंबता - AJAX एक HTTP अनुरोध बनाता है, और HTTP अनुरोध नेटवर्क पर किया जाता है और नेटवर्क विलंबता है
  • राज्य - एक अलग HTTP अनुरोध के माध्यम से लाए गए डेटा में HTML दस्तावेज़ को लाने वाले HTTP अनुरोध से कोई जानकारी शामिल नहीं होगी। आपको इस जानकारी की आवश्यकता हो सकती है (उदाहरण के लिए, यदि HTML डॉक्यूमेंट किसी फॉर्म सबमिट करने के जवाब में उत्पन्न होता है) और, यदि आप ऐसा करते हैं, तो इसे किसी भी तरह ट्रांसफर करना होगा। यदि आपने पृष्ठ में डेटा को एम्बेड करने से इनकार कर दिया है (जो आपके पास अगर आप इस तकनीक का उपयोग कर रहे हैं) तो वह आपको कुकीज़ / सत्रों तक सीमित करता है जो दौड़ की स्थिति के अधीन हो सकता है।

कार्यान्वयन उदाहरण

AJAX के साथ, आपको दो पृष्ठों की आवश्यकता है, एक वह स्थान है जहाँ PHP आउटपुट उत्पन्न करता है, और दूसरा वह है जहाँ जावास्क्रिप्ट को वह आउटपुट मिलता है:

मिल-data.php

/* Do some operation here, like talk to the database, the file-session
 * The world beyond, limbo, the city of shimmers, and Canada.
 *
 * AJAX generally uses strings, but you can output JSON, HTML and XML as well.
 * It all depends on the Content-type header that you send with your AJAX
 * request. */

echo json_encode(42); // In the end, you need to echo the result.
                      // All data should be json_encode()d.

                      // You can json_encode() any value in PHP, arrays, strings,
                      //even objects.

index.php (या वास्तविक पृष्ठ जो भी नाम दिया गया है)

<!-- snip -->
<script>
    function reqListener () {
      console.log(this.responseText);
    }

    var oReq = new XMLHttpRequest(); // New request object
    oReq.onload = function() {
        // This is where you handle what to do with the response.
        // The actual data is found on this.responseText
        alert(this.responseText); // Will alert: 42
    };
    oReq.open("get", "get-data.php", true);
    //                               ^ Don't block the rest of the execution.
    //                                 Don't wait until the request finishes to
    //                                 continue.
    oReq.send();
</script>
<!-- snip -->

42जब फ़ाइल लोड हो रही हो तो दो फ़ाइलों का उपरोक्त संयोजन सतर्क हो जाएगा ।

कुछ और पढ़ने की सामग्री

2. डेटा को पृष्ठ में कहीं भी इको करें, और DOM से जानकारी प्राप्त करने के लिए जावास्क्रिप्ट का उपयोग करें

यह विधि AJAX के लिए कम बेहतर है, लेकिन इसके फायदे अभी भी हैं। यह अभी भी PHP और जावास्क्रिप्ट के बीच अपेक्षाकृत अलग है इस अर्थ में कि जावास्क्रिप्ट में कोई PHP सीधे नहीं है।

पेशेवरों

  • फास्ट - DOM ऑपरेशन अक्सर जल्दी होते हैं, और आप बहुत अधिक डेटा को अपेक्षाकृत जल्दी स्टोर और एक्सेस कर सकते हैं।

विपक्ष

  • संभावित रूप से Unsemantic Markup - आमतौर पर, क्या होता है कि आप <input type=hidden>जानकारी को संग्रहीत करने के लिए किसी प्रकार का उपयोग करते हैं, क्योंकि जानकारी को बाहर निकालना आसान है inputNode.value, लेकिन ऐसा करने का अर्थ है कि आपके HTML में एक अर्थहीन तत्व है। HTML में <meta>दस्तावेज़ के बारे में डेटा के लिए तत्व है, और HTML 5 data-*विशेष रूप से जावास्क्रिप्ट के साथ पढ़ने के लिए डेटा के लिए विशेषताओं का परिचय देता है जो विशेष तत्वों से जुड़ा हो सकता है।
  • स्रोत तक की गंदगी - डेटा जो PHP उत्पन्न करता है, उसे सीधे HTML स्रोत में आउटपुट किया जाता है, जिसका अर्थ है कि आपको एक बड़ा और कम केंद्रित HTML स्रोत मिलता है।
  • संरचित डेटा प्राप्त करने के लिए कठोर - संरचित डेटा को मान्य HTML होना चाहिए, अन्यथा आपको स्वयं तार को बदलना और बदलना होगा।
  • आपके डेटा लॉजिक के लिए कसकर कपल PHP - क्योंकि PHP का इस्तेमाल प्रेजेंटेशन में किया जाता है, आप दोनों को अलग-अलग साफ़ नहीं कर सकते।

कार्यान्वयन उदाहरण

इसके साथ, विचार कुछ प्रकार के तत्व बनाने का है जो उपयोगकर्ता को प्रदर्शित नहीं किया जाएगा, लेकिन जावास्क्रिप्ट को दिखाई देगा।

index.php

<!-- snip -->
<div id="dom-target" style="display: none;">
    <?php
        $output = "42"; // Again, do some operation, get the output.
        echo htmlspecialchars($output); /* You have to escape because the result
                                           will not be valid HTML otherwise. */
    ?>
</div>
<script>
    var div = document.getElementById("dom-target");
    var myData = div.textContent;
</script>
<!-- snip -->

3. डेटा को सीधे जावास्क्रिप्ट पर इको करें

यह समझना शायद सबसे आसान है।

पेशेवरों

  • बहुत आसानी से लागू किया गया - इसे लागू करने में बहुत कम समय लगता है, और समझ में आता है।
  • गंदा स्रोत नहीं है - चर को सीधे जावास्क्रिप्ट में आउटपुट किया जाता है, इसलिए डोम प्रभावित नहीं होता है।

विपक्ष

  • आपके डेटा लॉजिक के लिए कसकर कपल PHP - क्योंकि PHP का इस्तेमाल प्रेजेंटेशन में किया जाता है, आप दोनों को अलग-अलग साफ़ नहीं कर सकते।

कार्यान्वयन उदाहरण

कार्यान्वयन अपेक्षाकृत सरल है:

<!-- snip -->
<script>
    var data = <?php echo json_encode("42", JSON_HEX_TAG); ?>; // Don't forget the extra semicolon!
</script>
<!-- snip -->

सौभाग्य!


70
"PHP में कोई तुच्छ जावास्क्रिप्ट एस्केप फ़ंक्शन नहीं है" - क्या गलत है json_encode?
क्वेंटिन

34
मैं "अत्यधिक असुरक्षित !!" और "संरचित डेटा कठिन है"। JSON ( जावास्क्रिप्ट ऑब्जेक्ट संकेतन, सब के बाद) के रूप में डेटा को एनकोड करें , और वहां आप जाएं!
el.pescado

14
AJAX अनुरोध करते समय महत्वपूर्ण ओवरहेड और कोड जटिलता अतुल्यकालिकता का परिचय क्या है? जावास्क्रिप्ट लाइट वेबसाइट पर काम करते समय - AJAX अनुरोध करना थकाऊ है और सर्वोत्तम अभ्यास नहीं है।
बेंजामिन ग्रुएनबाम

8
@BenjaminGruenbaum - जेएस अमान्य JSON अप्रासंगिक होने के कारण। मैं किसी भी JSON के बारे में नहीं सोच सकता जो एक असाइनमेंट के दाईं ओर जावास्क्रिप्ट में अमान्य है।
क्वेंटिन

7
@SecondRikudo विधि 3 में, वह उदाहरण वेबसाइट को मार सकता है। उदाहरण: <?php $output = '<!--<script>'; echo json_encode($output); ?>। देखें इस सवाल जानकारी के लिए। समाधान: JSON_HEX_TAGबचने के लिए उपयोग करें <और >(PHP 5.3.0 की आवश्यकता है)।
पैंग

90

मैं एक सरल उत्तर की कोशिश करने जा रहा हूं:

समस्या का स्पष्टीकरण

सबसे पहले, आइए घटनाओं के प्रवाह को समझते हैं जब एक पृष्ठ हमारे सर्वर से परोसा जाता है:

  • पहले PHP चलाया जाता है, यह क्लाइंट को दी जाने वाली HTML उत्पन्न करता है।
  • फिर, क्लाइंट को HTML डिलीवर कर दिया जाता है, उसके बाद PHP के साथ किया जाता है, मैं इस बात पर जोर देना चाहता हूं कि एक बार कोड सर्वर को छोड़ देगा - PHP इसके साथ किया जाता है और अब इसे एक्सेस नहीं कर सकता है।
  • फिर, जावास्क्रिप्ट के साथ HTML क्लाइंट तक पहुंचता है, जो उस HTML पर जावास्क्रिप्ट को निष्पादित कर सकता है।

तो वास्तव में, यहाँ याद रखने वाली मुख्य बात यह है कि HTTP स्टेटलेस है । एक बार सर्वर के अनुरोध के बाद, सर्वर उसे छू नहीं सकता। तो, यह हमारे विकल्प छोड़ता है:

  1. प्रारंभिक अनुरोध किए जाने के बाद क्लाइंट से अधिक अनुरोध भेजें ।
  2. शुरुआती अनुरोध में सर्वर को जो कहना था, उसे एनकोड करें।

समाधान

यही मूल प्रश्न है जो आपको खुद से पूछना चाहिए:

क्या मैं वेबसाइट या एप्लिकेशन लिख रहा हूं?

वेबसाइटें मुख्य रूप से पृष्ठ आधारित हैं, और पृष्ठ लोड समय को जितनी जल्दी हो सके उतनी ही तेजी से करने की आवश्यकता है (उदाहरण के लिए - विकिपीडिया)। वेब एप्लिकेशन अधिक AJAX के भारी होते हैं और क्लाइंट फास्ट जानकारी (उदाहरण के लिए - एक स्टॉक डैशबोर्ड) प्राप्त करने के लिए बहुत सारी गोल यात्राएं करते हैं।

वेबसाइट

प्रारंभिक अनुरोध किए जाने के बाद क्लाइंट से अधिक अनुरोध भेजना धीमा है क्योंकि इसके लिए अधिक HTTP अनुरोधों की आवश्यकता होती है जिनके लिए महत्वपूर्ण ओवरहेड है। इसके अलावा, AJAX अनुरोध करने के लिए इसे अतुल्यकालिकता की आवश्यकता होती है जब इसे पूरा करने के लिए हैंडलर की आवश्यकता होती है।

जब तक आपकी साइट सर्वर से उस जानकारी को प्राप्त करने के लिए एक आवेदन नहीं है, मैं एक और अनुरोध करने की सिफारिश नहीं करूंगा ।

आप तेजी से प्रतिक्रिया समय चाहते हैं जिसका रूपांतरण और लोड समय पर भारी प्रभाव पड़ता है। इस मामले में प्रारंभिक अपटाइम के लिए अजाक्स अनुरोध करना धीमी और अनावश्यक है।

आपके पास समस्या से निपटने के दो तरीके हैं

  • कुकी सेट करें - कुकीज़ HTTP अनुरोधों में भेजे गए हेडर हैं जो सर्वर और क्लाइंट दोनों पढ़ सकते हैं।
  • चर को JSON के रूप में एन्कोड करें - JSON जावास्क्रिप्ट ऑब्जेक्ट्स के बहुत करीब दिखता है और अधिकांश JSON ऑब्जेक्ट्स जावास्क्रिप्ट वेरिएबल मान्य होते हैं।

कुकी सेट करना वास्तव में बहुत मुश्किल नहीं है, आप बस इसे एक मूल्य प्रदान करते हैं:

setcookie("MyCookie", $value); // Sets the cookie to the value, remember, do not
                               // Set it with HTTP only to true.

फिर, आप जावास्क्रिप्ट का उपयोग करके इसे पढ़ सकते हैंdocument.cookie :

यहाँ एक शॉर्ट हैंड रोल किया गया पार्सर है, लेकिन मैंने जो उत्तर इसके ठीक ऊपर जोड़ा है, उसमें बेहतर परीक्षण किए गए हैं:

var cookies = document.cookie.split(";").
    map(function(el){ return el.split("="); }).
    reduce(function(prev,cur){ prev[cur[0]] = cur[1];return prev },{});

cookies["MyCookie"] // Value set with PHP.

कुकीज़ थोड़े डेटा के लिए अच्छी हैं। यह वही है जो ट्रैकिंग सेवाएं अक्सर करती हैं।

एक बार जब हमारे पास अधिक डेटा होता है, तो हम इसे JSON के साथ जावास्क्रिप्ट चर के अंदर एन्कोड कर सकते हैं:

<script>
    var myServerData = <?=json_encode($value)?>; // Don't forget to sanitize
                                                 //server data
</script>

मान लिया जाए कि $valueयह json_encodePHP की तरफ है (यह आमतौर पर है)। यह तकनीक वह है जो स्टैक ओवरफ्लो उदाहरण के लिए अपनी चैट के साथ करता है (केवल PHP के बजाय .NET का उपयोग करके)।

आवेदन

यदि आप एक एप्लिकेशन लिख रहे हैं - अचानक प्रारंभिक लोड समय हमेशा अनुप्रयोग के चल रहे प्रदर्शन जितना महत्वपूर्ण नहीं होता है, और यह डेटा और कोड को अलग-अलग लोड करने के लिए भुगतान करना शुरू कर देता है।

मेरा उत्तर यहां बताता है कि जावास्क्रिप्ट में AJAX का उपयोग करके डेटा को कैसे लोड किया जाए:

function callback(data){
    // What do I do with the response?
}

var httpRequest = new XMLHttpRequest;
httpRequest.onreadystatechange = function(){
    if (httpRequest.readyState === 4) { // Request is done
        if (httpRequest.status === 200) { // successfully
            callback(httpRequest.responseText); // We're calling our method
        }
    }
};
httpRequest.open('GET', "/echo/json");
httpRequest.send();

या jQuery के साथ:

$.get("/your/url").done(function(data){
    // What do I do with the data?
});

अब, सर्वर को केवल एक /your/urlरूट / फ़ाइल शामिल करने की आवश्यकता है जिसमें कोड है जो डेटा को पकड़ता है और आपके मामले में इसके साथ कुछ करता है:

<$php
     ...
     $val = myService->getValue(); // Makes an API and database call
     echo json_encode($val); // Write it to the output
 $>

इस तरह, हमारी जावास्क्रिप्ट फ़ाइल डेटा मांगती है और कोड या लेआउट के लिए पूछने के बजाय इसे दिखाती है। यह क्लीनर है और आवेदन अधिक होने के कारण भुगतान करना शुरू कर देता है। यह चिंताओं का बेहतर पृथक्करण भी है और यह बिना किसी सर्वर साइड तकनीक के क्लाइंट साइड कोड का परीक्षण करने की अनुमति देता है जो एक और प्लस है।

पोस्टस्क्रिप्ट: जब आप PHP से जावास्क्रिप्ट में कुछ भी इंजेक्ट करते हैं तो आपको XSS अटैक वैक्टर के बारे में बहुत जागरूक होना चाहिए । यह बहुत मान ठीक से बचने के लिए कठिन है और यह संदर्भ संवेदनशील है। यदि आप XSS से निपटने के बारे में अनिश्चित हैं, या इससे अनजान हैं - कृपया इस OWASP लेख , इस एक और इस प्रश्न को पढ़ें ।


4
@cHao अधिक सामान्यतः - एन्कोडिंग को वर्णों के अनुक्रम के रूप में परिभाषित किया जाता है और वैचारिक वस्तुओं का अस्तित्व एक दार्शनिक है। हालाँकि, JSON ऑब्जेक्ट्स जैसी कुछ चीज़ें हैं और उन्हें JSON व्याकरण द्वारा परिभाषित किया गया है। {}एक वैध JSON ऑब्जेक्ट है - json.org
बेंजामिन

1
यदि आप उस परिभाषा का उपयोग कर रहे हैं, हालाँकि, तब सभी "JSON ऑब्जेक्ट्स" JS में मान्य हैं।
cHao

1
@cHao सूक्ष्मता पर ध्यान दें: जावास्क्रिप्ट की वस्तु की धारणा है और JSON की वस्तु की धारणा है - वे समान नहीं हैं। जब लोग "JSON ऑब्जेक्ट" शब्द का दुरुपयोग करते हैं, तो उनका मतलब एक JS ऑब्जेक्ट होता है, जहां जावास्क्रिप्ट भूमि में - JSON का उपयोग डेटा क्रमांकन प्रारूप के रूप में किया जाता है और JSON ऑब्जेक्ट्स स्ट्रिंग्स के अंदर दिखाई देते हैं (सर्वर-साइड भाषाओं में SQL प्रश्नों की तरह)। हालाँकि, इस उत्तर में JSON विधि इस तथ्य पर निर्भर करती है कि अधिकांश JSON ऑब्जेक्ट भी मान्य हैं JavaScript ऑब्जेक्ट इसलिए हम जावास्क्रिप्ट कोड में एक JSON ऑब्जेक्ट लिखते हैं।
बेंजामिन ग्रुएनबाम

1
@ हाहा आह, लेकिन मैंने कल इस पल को मना लिया है :) stackoverflow.com/questions/23752156/…
बेंजामिन ग्रुएनबाउम

2
ठीक है, तुमने मुझे ढूँढ लिया। :) यह अभी भी सुरक्षित है, हालांकि; PHP का डिफ़ॉल्ट व्यवहार ऐसे पात्रों (अन्य गैर-ASCII वर्णों के साथ) से बचने के लिए है, इसलिए वे कभी भी आउटपुट को छोड़कर अपना रास्ता नहीं बनाते हैं \u2028आदि के रूप में आपको स्पष्ट रूप से यह बताना होगा कि ऐसा न करें।
cHao

85

मैं आमतौर पर HTML में डेटा- * विशेषताओं का उपयोग करता हूं।

<div class="service-container" data-service="<?php echo $myService->getValue(); ?>">

</div>

<script>
    $(document).ready(function() {
        $('.service-container').each(function() {
            var container = $(this);
            var service = container.data('service');

            // Variable "service" now contains the value of $myService->getValue();
        });
    });
</script>

यह उदाहरण jQuery का उपयोग करता है, लेकिन इसे किसी अन्य लाइब्रेरी या वेनिला जावास्क्रिप्ट के लिए अनुकूलित किया जा सकता है।

आप यहां पर डेटासेट की संपत्ति के बारे में अधिक पढ़ सकते हैं: https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement.dataset


4
मैं सहमत हूं, एक साधारण समस्या के लिए एक फैंसी समाधान का अधिक विश्लेषण और कार्यान्वयन नहीं करना चाहता हूं। यह विधि PHP को जावास्क्रिप्ट से अलग करती है, जिससे PHP अभी भी केवल HTML उत्पन्न करती है, जबकि जावास्क्रिप्ट PHP फ़ाइल के लिए बाहरी हो सकता है।
ALDS

2
मैं मानता हूं कि यह सबसे अच्छा विकल्प है। यह बिना विलंबता के सभी सुरक्षा मुद्दों को हल करता है। आप JS को अपने HTML पृष्ठों से पूरी तरह से बाहर रख सकते हैं। HTML को एप्लिकेशन सर्वर द्वारा परोसा जाना चाहिए, लेकिन JS (और CSS) ऐसा नहीं करता है। यह अधिक अर्थपूर्ण भी है।
रयान

1
@ क्वेंटिन आपको सभी आउटपुट से बचना चाहिए, जब तक कि आउटपुट स्वयं एचटीएमएल न हो।
युईकन्नू

2
@asdasd - हाँ, मैं सिर्फ सामान्य मामले के बजाय आपके उत्तर में कोड के साथ विशिष्ट समस्या का समाधान कर रहा था।
क्वेंटिन

1
@ कंजी - कोई श्रेष्ठ अभ्यास नहीं है; divठीक है, लेकिन आप अपनी पसंद के किसी भी टैग का उपयोग कर सकते हैं; bodyहालांकि में होना चाहिए ।
टिम्म

38
<script>
  var jsvar = <?php echo json_encode($PHPVar); ?>;
</script>

json_encode () की आवश्यकता है:

  • PHP 5.2.0 या अधिक
  • $PHPVar यूटीएफ -8, यूनिकोड के रूप में एन्कोडेड।

19

बस निम्न विधियों में से एक का उपयोग करें।

<script type="text/javascript">
var js_variable  = '<?php echo $php_variable;?>';
<script>

या

<script type="text/javascript">
    var js_variable = <?php echo json_encode($php_variable); ?>; 
</script>

4
मौजूदा जवाबों में यह क्या मूल्य जोड़ता है?
बेंजामिन ग्रुएनबाम

5
इसे सरल और सीधा रखना। उन सभी उपयोगकर्ताओं के लिए जिनके पास गहन स्पष्टीकरण में खुदाई करने के लिए बहुत समय है
निशांत मेंदिरत्ता

1
सरल बेहतर है
डोबेरॉन

यह एक मूर्खतापूर्ण प्रश्न हो सकता है, लेकिन मैं PHP दुनिया के लिए बिल्कुल नया हूं। एक बार जब हम उपरोक्त कोड को .php फ़ाइल में लिखते हैं, तो मैं अपनी जावास्क्रिप्ट फ़ाइल या मेरी "index.html" फ़ाइल में "js_variable" का उपयोग कैसे करूं?
अंकित प्रजापति

@AnkitPrajapati दस्तावेज़ तैयार स्थिति की जाँच करके इसे एक्सेस करने का प्रयास करें। निम्नलिखित स्क्रिप्ट का उपयोग करना। document.onreadystatechange = () => { if (document.readyState === 'complete') { // document ready alert(js_variable) } };
निशांत मेंदीरत्ता

11

मुझे काफी पसंद है जिस तरह से वर्डप्रेस अपने enqueue और स्थानीयकरण के कार्यों के साथ काम करता है , इसलिए उस मॉडल का अनुसरण करते हुए, मैंने स्क्रिप्ट निर्भरता के अनुसार एक स्क्रिप्ट को पृष्ठ में डालने के लिए और स्क्रिप्ट के लिए अतिरिक्त डेटा उपलब्ध कराने के लिए एक सरल वर्ग लिखा।

class mHeader {

    private $scripts = array();

    /**
     * @param string $id        Unique script identifier
     * @param string $src      Script src attribute
     * @param array  $deps       An array of dependencies ( script identifiers ).
     * @param array  $data       An array, data that will be json_encoded and available to the script.
     */
    function enqueue_script($id, $src, $deps = array(), $data = array()) {
        $this->scripts[$id] = array('src' => $src, 'deps' => $deps, 'data' => $data);
    }

    private function dependencies($script) {
        if ($script['deps']) {
            return array_map(array($this, 'dependencies'), array_intersect_key($this->scripts, array_flip($script['deps'])));
        }
    }

    private function _unset($key, &$deps, &$out) {
        $out[$key] = $this->scripts[$key];
        unset($deps[$key]);
    }

    private function flattern(&$deps, &$out = array()) {

        foreach($deps as $key => $value) {
            empty($value) ? $this->_unset($key, $deps, $out) : $this->flattern( $deps[$key], $out);
        }
    }

    function print_scripts() {

        if (!$this->scripts)
            return;

        $deps = array_map(array($this, 'dependencies'), $this->scripts);
        while ($deps)
            $this->flattern($deps, $js);

        foreach($js as $key => $script) {
            $script['data'] && printf("<script> var %s = %s; </script>" . PHP_EOL, key($script['data']), json_encode(current( $script['data'])));
            echo "<script id=\"$key-js\" src=\"$script[src]\" type=\"text/javascript\"></script>" . PHP_EOL;
        }
    }
}

enqueue_script()फ़ंक्शन को कॉल स्क्रिप्ट जोड़ने, अन्य स्क्रिप्ट पर स्रोत और निर्भरता सेट करने और स्क्रिप्ट के लिए आवश्यक अतिरिक्त डेटा के लिए है।

$header = new mHeader();

$header->enqueue_script('jquery-ui', '//ajax.googleapis.com/ajax/libs/jqueryui/1.10.4/jquery-ui.min.js', array('jquery'));
$header->enqueue_script('jquery', '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js');
$header->enqueue_script('custom-script', '//custom-script.min.js', array('jquery-ui'), array('mydata' => array('value' => 20)));

$header->print_scripts();

और, print_scripts()उपरोक्त उदाहरण की विधि इस आउटपुट को भेजेगी:

<script id="jquery-js" src="//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js" type="text/javascript"></script>
<script id="jquery-ui-js" src="//ajax.googleapis.com/ajax/libs/jqueryui/1.10.4/jquery-ui.min.js" type="text/javascript"></script>
<script> var mydata = {"value":20}; </script>
<script id="custom-script-js" src="//custom-script.min.js" type="text/javascript"></script>

इस तथ्य के बावजूद कि स्क्रिप्ट that jquery ’को-jquery-ui’ के बाद परिगणित किया जाता है, इसे पहले मुद्रित किया जाता है क्योंकि इसे ery jquery-ui ’में परिभाषित किया जाता है कि यह qu jquery’ पर निर्भर करता है। Data कस्टम-स्क्रिप्ट ’के लिए अतिरिक्त डेटा एक नई स्क्रिप्ट ब्लॉक के अंदर होता है और इसे सामने रखा जाता है, इसमें ऐसी mydataवस्तु होती है जो अतिरिक्त डेटा रखती है, जो अब-कस्टम-स्क्रिप्ट’ के लिए उपलब्ध है।


10

इसे इस्तेमाल करे:

<?php
    echo "<script> var x = " . json_encode($phpVariable) . "</script>";
?>

-

-थोड़ी देर तक यही कोशिश करते रहे

यद्यपि यह काम करता है, हालांकि यह प्रदर्शन को धीमा कर देता है। चूंकि PHP एक सर्वर-साइड स्क्रिप्ट है, जबकि जावास्क्रिप्ट एक उपयोगकर्ता पक्ष है।


4
हम लंबे उत्तर की तलाश कर रहे हैं जो कुछ स्पष्टीकरण और संदर्भ प्रदान करते हैं। केवल एक-पंक्ति का उत्तर न दें; समझाएं कि आपका उत्तर सही क्यों है, आदर्श रूप से उद्धरणों के साथ। स्पष्टीकरण को शामिल नहीं करने वाले उत्तरों को हटाया जा सकता है। यह प्रश्न पर लिखा गया है।
का भूत

3
समझाने के लिए ज्यादा कुछ नहीं एक <script टैग> में अपना php वैरिएबल लिखने के लिए जो कि php कोड में गूँज रहा है
Yosra Nagati

5
क्या आपको यकीन है? क्या आपने इस प्रश्न का शीर्ष उत्तर देखा है? यह काफी कुछ समझाता है। यह उल्लेख करने के लिए नहीं कि आपका समाधान सुरक्षित नहीं है। $phpVariable = '42"; alert("I am evil!");';
मदारा का भूत

9
यह मेरा सुझाव है जिसने मेरी समस्या को हल कर दिया है और मुझे पिछले उत्तरों में यह नहीं मिला इसलिए मैंने जोड़ा, उम्मीद है कि कोई इसे दिलचस्प
पाएगा

1
क्या इको को वेब पेज पर प्रिंट करने के लिए यहां जोड़ा गया है, जिसमें यह php कोड है या यह डेटा को js वेरिएबल में डालने के लिए सिंटैक्स का हिस्सा है। @ YosraNagati
SUMIT KUMAR SINGH

8
myPlugin.start($val); // Tried this, didn't work

यह काम नहीं करता है क्योंकि $valजहाँ तक जावास्क्रिप्ट का संबंध है, अपरिभाषित है, यानी PHP कोड ने कुछ भी आउटपुट नहीं किया $val। अपने ब्राउज़र में स्रोत को देखने का प्रयास करें और यहाँ वह है जो आप देखेंगे:

myPlugin.start(); // I tried this, and it didn't work

तथा

<?php myPlugin.start($val); ?> // This didn't work either

यह काम नहीं करता है क्योंकि PHP myPluginएक स्थिरांक के रूप में इलाज करने की कोशिश करेगा और जब वह विफल हो जाएगा तो वह इसे स्ट्रिंग के रूप में 'myPlugin'मानने की कोशिश करेगा जिसे वह PHP फ़ंक्शन के आउटपुट के साथ समेटने की कोशिश करेगाstart() और चूंकि यह अपरिभाषित है, इसलिए यह एक घातक परिणाम देगा त्रुटि।

तथा

 myPlugin.start(<?=$val?> // This works sometimes, but sometimes it fails

हालांकि, यह काम करने की सबसे अधिक संभावना है, क्योंकि PHP कोड अपेक्षित तर्क के साथ वैध जावास्क्रिप्ट का उत्पादन कर रहा है, अगर यह विफल रहता है, तो संभावना यह है क्योंकि myPlugin अभी तक खो गया है। अपने निष्पादन का क्रम जांचें।

इसके अलावा, आपको ध्यान देना चाहिए कि PHP कोड आउटपुट असुरक्षित है और इसे फ़िल्टर किया जाना चाहिए json_encode()

संपादित करें

क्योंकि मुझे लापता कोष्ठक में ध्यान नहीं दिया गया myPlugin.start(<?=$val?>: - \

जैसा कि @ सैकंड रिकूडो बताते हैं, इसे सही ढंग से काम $valकरने के लिए समापन कोष्ठक को शामिल करना होगा, उदाहरण के लिए:$val="42);"

इसका मतलब है कि जावास्क्रिप्ट अब उत्पादन myPlugin.start(42);करेगा और जावास्क्रिप्ट कोड द्वारा निष्पादित होने पर अपेक्षित रूप से काम करेगा।


JSON आपके डेटा को इनकोड करता है:myPlugin.start(<?=json_encode($val)?>);
Kingprawn

6

मैं PHP का उपयोग करके जावास्क्रिप्ट चर असाइन करने के लिए एक आसान विधि के साथ आया हूं।

यह PHP चर को संग्रहीत करने के लिए HTML5 डेटा विशेषताओं का उपयोग करता है और फिर इसे पृष्ठ लोड पर जावास्क्रिप्ट को सौंपा गया है।

एक पूर्ण ट्यूटोरियल यहां पाया जा सकता है

उदाहरण:

<?php
    $variable_1 = "QNimate";
    $variable_2 = "QScutter";
?>
    <span id="storage" data-variable-one="<?php echo $variable_1; ?>" data-variable-two="<?php echo $variable_2; ?>"></span>
<?php

यहाँ जावास्क्रिप्ट कोड है

var variable_1 = undefined;
var variable_2 = undefined;

window.onload = function(){
    variable_1 = document.getElementById("storage").getAttribute("data-variable-one");
    variable_2 = document.getElementById("storage").getAttribute("data-variable-two");
}

2
यदि डेटा विशेषताएँ समस्या का एक उचित समाधान हैं, तो आप मूल प्रश्न के समान समस्या को समाप्त करते हैं यदि आप उनमें डेटा से बच नहीं जाते हैं। यह सिर्फ आपको जेएस के बजाय HTML के लिए भागने की जरूरत है।
क्वेंटिन

5
  1. JSON में डेटा परिवर्तित करें
  2. JSON फ़ाइल प्राप्त करने के लिए AJAX को कॉल करें
  3. JSON को जावास्क्रिप्ट ऑब्जेक्ट में कन्वर्ट करें

उदाहरण:

चरण 1

<?php

   $servername = "localhost";
   $username = "";
   $password = "";
   $dbname = "";
   $conn = new mysqli($servername, $username, $password, $dbname);

   if ($conn->connect_error) {
      die("Connection failed: " . $conn->connect_error);
   } 

   $sql = "SELECT id, name, image FROM phone";
   $result = $conn->query($sql);

   while($row = $result->fetch_assoc()){ 
      $v[] = $row;    
   }

  echo json_encode($v);

  $conn->close();
?>

चरण 2

function showUser(fnc) {
   var xhttp = new XMLHttpRequest();

   xhttp.onreadystatechange = function() {
      if (this.readyState == 4 && this.status == 200) {
         // STEP 3    
         var p = JSON.parse(this.responseText);
      }
   }
}

5

यहां एक है जिसे मैं एक विकल्प के रूप में पोस्ट नहीं करता हूं। यह अजाक्स का उपयोग करने के समान है, लेकिन स्पष्ट रूप से अलग है।

सबसे पहले, स्क्रिप्ट के स्रोत को सीधे PHP फ़ाइल में सेट करें।

<script type="text/javascript" src="url_to_your_php_file.php" /></script>

आप इस तरह के उदाहरण के रूप में PHP फ़ाइल के लिए एक चर वापस पारित कर सकता है:

<script type="text/javascript" src="url_to_your_php_file.php?var1=value1" /></script>

फिर "your_php_file.php" में:

<?php
    // THIS IS A SIMPLE EXAMPLE
    // it demonstrates one method of using the src attribute to link
    // to a PHP file which can generate JavaScript code dynamically
    // and share data between PHP and JavaScript
    // you may take this learning example and develop it further
    // relying on your own coding skills for validating data
    // and avoiding errors, of course
    header('content-type: text/javascript');

    // If you pass a $_GET variable from the JavaScript
    // you should add code to validate your $_GET variable(s)

    // You can add code to query a database
    // using $_GET['var1'] or some other criteria

    // You can add simple variable assignments
    $value = 'some value';

    // For the OP's needs (assumes the class object has been defined)
    $val = $myService->getValue();
?>

function name() {
    // Pay attention because you need to use quotes properly
    // and account for possible quotes in the variable strings
    // to avoid both PHP and JavaScript errors
    // example assumes $val has been returned as a string
    // validate $val as needed using your method of choice
    var example1 = <?php echo '"' . $val . '"'; ?>;
    var example2 = <?php echo '"' . $value . '"'; ?>;
    var example3 = <?php echo '"some other data"'; ?>;
    alert( example1 + ' / ' + example2 );
}

<?php
    // You may even want to include additional files (.php or .js, etc.)
    @include 'local_path_to_some_other_js_file.js';
    @include 'local_path_to_some_other_php_file.php';

    exit;
?>

चूंकि पीएचपी स्क्रिप्ट में चर मौजूद है जो HTML उत्पन्न कर रहा है, आप गतिशील रूप से उत्पन्न करने के महत्वपूर्ण चरण से चूक गए var1=value1। जैसा कि यह खड़ा है कि आपकी स्क्रिप्ट टूटने वाली है यदि डेटा में एक 'चरित्र शामिल है ।
Quentin

@ क्विंट कोड प्रस्तुत किए बिना त्रुटि के साथ काम करता है। इसका उपयोग प्रदर्शित करना है। यदि कोई प्रोग्रामर कोडिंग में दूर है, तो वे $ _GET चर में सिंगल-कोट्स / डबल-कोट्स के निहितार्थ को समझेंगे - जिन्हें वैसे भी urlencoded किया जाना चाहिए। var1 != [some HTML code]... स्पष्ट रूप से var1=="value1"। स्पष्ट रूप से कहें, तो आप गलत हैं कि मैंने कुछ भी याद किया। उदाहरण स्क्रिप्ट पूर्ण है, और, जैसा कि आप देख सकते हैं, कोई HTML उत्पन्न नहीं कर रहा है - और ओपी ने HTML का उल्लेख नहीं किया है। यह कुछ ट्रिगर खुश
बायपासर द्वारा डाउनवोट के

प्रश्न में कोड दर्शाता है कि ओपी को उद्धृत / भागने से समझ में नहीं आता है। उस बारे में समझ की कमी पूरी समस्या है! उदाहरण पूरा होने के दौरान, यह सवाल में व्यक्त समस्या को हल करने का एक उदाहरण नहीं है।
क्वेंटिन

@ क्वेंटिन वास्तव में ओपी कैसे प्रदर्शित करता है कि वे उद्धृत / भागने से नहीं समझते हैं? यह समस्या को हल करने के तरीके का एक उदाहरण है, क्योंकि ओपी ने पूछा कि जावास्क्रिप्ट डेटा को जावास्क्रिप्ट में कैसे
लाया जाए

इस कोड के टुकड़े के साथ $valजो भागने या एनकोड करने के लिए कुछ भी नहीं करता है और जो कभी-कभी काम करता है और कभी-कभी नहीं होता है:myPlugin.start(<?=$val?> // this works sometimes, but sometimes it fails
क्वेंटिन

3

यहाँ इस चाल है:

  1. यहाँ उस चर का उपयोग करने के लिए आपका 'PHP' है:

    <?php
        $name = 'PHP variable';
        echo '<script>';
        echo 'var name = ' . json_encode($name) . ';';
        echo '</script>';
    ?>
  2. अब आपके पास एक जावास्क्रिप्ट चर कहा जाता है 'name', और यहाँ उस चर का उपयोग करने के लिए आपका जावास्क्रिप्ट कोड है:

    <script>
         console.log("I am everywhere " + name);
    </script>

क्या इसे पाने का कोई तरीका है ताकि यह वास्तव में स्रोत कोड में प्रिंट न हो? मेरे पास एक विशाल सरणी है जो मैं गुजर रहा हूं, और यह स्रोत को रोक देता है।
विलियम हॉली

1
क्या आप एक उदाहरण परीक्षण मामला प्रदान कर सकते हैं?
रामिन तागीज़ादा

इस के रूप में में "3. इको सीधे जावास्क्रिप्ट करने के लिए डेटा" एक ही नहीं है इस सवाल का जवाब ? यह एक बेहतर भी लग रहा है।
कांजी

3

मान लीजिए कि आपका चर हमेशा पूर्णांक है। उस मामले में यह आसान है:

<?PHP
    $number = 4;

    echo '<script>';
    echo 'var number = ' . $number . ';';
    echo 'alert(number);';
    echo '</script>';
?>

आउटपुट :

<script>var number = 4;alert(number);</script>

मान लीजिए कि आपका वैरिएबल पूर्णांक नहीं है, लेकिन यदि आप उपरोक्त विधि को आजमाते हैं तो आपको कुछ इस तरह मिलेगा:

<script>var number = abcd;alert(number);</script>

लेकिन जावास्क्रिप्ट में यह एक सिंटैक्स त्रुटि है।

तो PHP में हमारे पास एक फ़ंक्शन कॉल है json_encodeजो स्ट्रिंग को JSON ऑब्जेक्ट में एन्कोड करता है।

<?PHP
    $number = 'abcd';

    echo '<script>';
    echo 'var number = ' . json_encode($number) . ';';
    echo 'alert(number);';
    echo '</script>';
?>

चूंकि abcdJSON है "abcd", यह इस तरह दिखता है:

<script>var number = "abcd";alert(number);</script>

आप सरणियों के लिए एक ही विधि का उपयोग कर सकते हैं:

<?PHP
    $details = [
    'name' => 'supun',
    'age' => 456,
    'weight' => '55'
    ];

    echo '<script>';
    echo 'var details = ' . json_encode($details) . ';';
    echo 'alert(details);';
    echo 'console.log(details);';
    echo '</script>';
?>

और आपका जावास्क्रिप्ट कोड इस तरह दिखता है:

<script>var details = {"name":"supun","age":456,"weight":"55"};alert(details);console.log(details);</script>

कंसोल आउटपुट

यहां छवि विवरण दर्ज करें


2

बहुत शोध के बाद, मैंने पाया कि सबसे आसान तरीका सभी प्रकार के चर को आसानी से पार करना है।

सर्वर स्क्रिप्ट में, आपके पास दो चर हैं, और आप उन्हें क्लाइंट स्क्रिप्ट में भेजने का प्रयास कर रहे हैं:

$php_var1 ="Hello world";
$php_var2 ="Helloow";
echo '<script>';
echo 'var js_variable1= ' . json_encode($php_var1) . ';';
echo 'var js_variable2= ' . json_encode($php_var2) . ';';
echo '</script>';

आपके किसी भी जावास्क्रिप्ट कोड को पृष्ठ पर बुलाया जाता है, बस उन चरों को कहते हैं।


1

मुझे लगता है कि संचारित करने के लिए डेटा एक स्ट्रिंग है।

जैसा कि अन्य टिप्पणीकारों ने कहा है, AJAX एक संभव समाधान है, लेकिन विपक्ष पेशेवरों से आगे निकल जाता है: इसकी एक विलंबता है और इसे प्रोग्राम करना कठिन है (यह सर्वर और क्लाइंट-साइड दोनों मान प्राप्त करने के लिए कोड की आवश्यकता है), जब एक सरल बच निकलने का कार्य पर्याप्त होना चाहिए।

इसलिए, हम बच कर वापस आ रहे हैं। यदि आप पहले से ही UTF-8 के रूप में स्रोत स्ट्रिंग को एनकोड करते हैं तो यहjson_encode($string) काम करता है क्योंकि यह पहले से ही नहीं है, क्योंकि इसके लिए UTF-8 डेटा की आवश्यकता होती है। यदि स्ट्रिंग ISO-8859-1 में है तो आप बस उपयोग कर सकते हैं ; अन्यथा आप हमेशा उपयोग कर सकते हैंjson_encodejson_encode(utf8_encode($string))iconv पहले रूपांतरण करने के लिए ।

लेकिन एक बड़ा गेटा है। यदि आप इसे घटनाओं में उपयोग कर रहे हैं, तो आपको htmlspecialchars()इसे सही कोड बनाने के लिए परिणाम पर चलाने की आवश्यकता है । और फिर आपको या तो घटना को घेरने के लिए दोहरे उद्धरण चिह्नों का उपयोग करने के लिए सावधान रहना होगा, या हमेशा ENT_QUOTEShtmlspecialchars में जोड़ना होगा। उदाहरण के लिए:

<?php
    $myvar = "I'm in \"UTF-8\" encoding and I have <script>script tags</script> & ampersand!";
    // Fails:
    //echo '<body onload="alert(', json_encode($myvar), ');">';
    // Fails:
    //echo "<body onload='alert(", json_encode($myvar), ");'>";
    // Fails:
    //echo "<body onload='alert(", htmlspecialchars(json_encode($myvar)), ");'>";

    // Works:
    //echo "<body onload='alert(", htmlspecialchars(json_encode($myvar), ENT_QUOTES), ");'>";
    // Works:
    echo '<body onload="alert(', htmlspecialchars(json_encode($myvar)), ');">';

    echo "</body>";

हालाँकि, आप htmlspecialcharsनियमित जावास्क्रिप्ट कोड (कोड <script>... </script>टैग्स में संलग्न कोड ) का उपयोग नहीं कर सकते । htmlspecialcharsइवेंट कोड लिखते समय परिणाम को भूलकर इस फ़ंक्शन का उपयोग गलतियों से होने का खतरा होता है ।

ऐसा फ़ंक्शन लिखना संभव है जिसमें वह समस्या न हो, और घटनाओं और नियमित जावास्क्रिप्ट कोड दोनों में उपयोग किया जा सकता है, जब तक आप अपनी घटनाओं को हमेशा एक उद्धरण में, या हमेशा दोहरे उद्धरण में संलग्न करते हैं। यहाँ मेरा प्रस्ताव है, उन्हें दोहरे उद्धरण चिह्नों में होना चाहिए (जो मुझे पसंद हैं):

<?php
    // Optionally pass the encoding of the source string, if not UTF-8
    function escapeJSString($string, $encoding = 'UTF-8')
    {
        if ($encoding != 'UTF-8')
            $string = iconv($encoding, 'UTF-8', $string);
        $flags = JSON_HEX_TAG|JSON_HEX_AMP|JSON_HEX_APOS|JSON_HEX_QUOT|JSON_UNESCAPED_SLASHES;
        $string = substr(json_encode($string, $flags), 1, -1);
        return "'$string'";
    }

फ़ंक्शन को PHP 5.4+ की आवश्यकता है। उदाहरण उपयोग:

<?php
    $myvar = "I'm in \"UTF-8\" encoding and I have <script>script tags</script> & ampersand!";
    // Note use of double quotes to enclose the event definition!
    echo '<body onload="alert(', escapeJSString($myvar), ');">';
    // Example with regular code:
    echo '<script>alert(', escapeJSString($myvar), ');</script>';
    echo '</body>';

0

अपने कोड के अनुसार

<$php
     $val = $myService->getValue(); // Makes an API and database call
     echo '<span id="value">'.$val.'</span>';
$>

अब आप DOM का उपयोग करके मान प्राप्त कर सकते हैं, इनर आईडी के HTML का उपयोग कर सकते हैं, इस मामले में आपको सर्वर, या अजाक्स या किसी अन्य चीज के लिए कोई कॉल करने की आवश्यकता नहीं है।

आपका पेज PHP का उपयोग करके इसे प्रिंट करेगा, और आप DOM का उपयोग करके जावास्क्रिप्ट प्राप्त करेंगे।


इस कोड को XSS की चपेट में है, क्योंकि यह की तरह वर्ण से बचें नहीं है <और >। इसके अलावा, इसी तरह के समाधान पहले से ही सुझाए गए हैं।
माइकल पेरोलकोव्स्की

0
<?php

    $val = $myService->getValue(); // Makes an API and database call

    echo "
        <script>
            myPlugin.start({$val});
        </script> ";

?>

0

पीएचपी

$fruits = array("apple" => "yellow", "strawberry" => "red", "kiwi" => "green");
<script>
    var color = <?php echo json_encode($fruits) ?>;
</script>
<script src="../yourexternal.js"></script>

जेएस (yourexternal.js)

alert("The apple color is" + color['apple'] + ", the strawberry color is " + color['strawberry'] + " and the kiwi color is " + color['kiwi'] + ".");

आउटपुट

सेब का रंग पीला, स्ट्रॉबेरी का रंग लाल और कीवी का रंग हरा होता है।


-2

जिन लोगों को नीचे दिए गए कोड का उपयोग करने में कुछ समस्या है और यह <?php echo $username?>कुछ इस तरह का दिखावा करता रहता है, वह इस T AddType एप्लिकेशन / x-httpd-php .html .htm ’को जोड़कर mime_module सेक्शन में httpd.conf को संपादित करें क्योंकि यह अक्षम हो सकता है। डिफ़ॉल्ट रूप से।

<?php
    $username = 1;
?>

<script type="text/javascript">
    var myData = <?php echo $username ?>;
    console.log(myData);
    alert(myData);
</script>

@MadaraUchiha आप बता सकते हैं क्यों?
निकिता Nik

3
क्योंकि अगर है $username === "hello", तो आपके पास है var myData = hello;जो बुरी तरह से टूट जाएगा।
मदार का भूत

-2

उपयोग:

<?php
    $your_php_variable= 22;
    echo "<script type='text/javascript'>var your_javascript_variable = $your_php_variable;</script>";
?>

और वह काम करेगा। यह सिर्फ एक जावास्क्रिप्ट चर असाइन कर रहा है और फिर एक मौजूदा PHP चर के मूल्य को पारित कर रहा है। चूंकि PHP यहां जावास्क्रिप्ट लाइनों को लिखती है, इसमें PHP चर का मूल्य है और इसे सीधे पास कर सकते हैं।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.