javascript - Why does appending a <script> to a dynamically created <iframe> seem to run the script in the parent page? -


मैं एक & lt; iframe & gt; जावास्क्रिप्ट का उपयोग कर, फिर एक & lt; स्क्रिप्ट & gt; तत्व & lt; iframe & gt; के लिए तत्व जिसे मैं & lt; iframe & gt; d दस्तावेज़ के संदर्भ में चलाना चाहता हूं।

दुर्भाग्यवश, ऐसा लगता है कि मैं कुछ गलत कर रहा हूं - मेरा जावास्क्रिप्ट सफलतापूर्वक निष्पादित होता है, लेकिन & lt; स्क्रिप्ट & gt; पैरेंट पेज है, & lt; iframe & gt; d दस्तावेज़ नहीं है जब भी ब्राउज़र iframe_test.js का अनुरोध करता है, तो मुझे फ़ायरबग के "नेट" टैब में 301 त्रुटि भी मिलती है, हालांकि यह फिर से अनुरोध करता है (सुनिश्चित क्यों नहीं?) सफलतापूर्वक।

यह मैं जिस कोड का उपयोग कर रहा हूं (पर लाइव डेमो):

iframe_test.html

  & lt;! DOCTYPE html public "- // W3C // डीटीटी एक्सएचटीएमएल 1.0 सशक्त // एन "" http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> & Lt; html xmlns = "http://www.w3.org/1999/xhtml" xml: lang = "en" lang = "en" & gt; & Lt; शीर्ष & gt; & Lt; मेटा http-equiv = "सामग्री-प्रकार" सामग्री = "पाठ / html; वर्णसेट = यूटीएफ -8" / & gt; & Lt; title & gt; & amp; lt; आइफ्रेम & amp; gt; परीक्षण & lt; / title & gt; & Lt; / head & gt; & LT; बॉडी & gt; & Lt; div id = "बाल्टी" & gt; & lt; / div & gt; & Lt; स्क्रिप्ट प्रकार = "टेक्स्ट / जावास्क्रिप्ट" src = "http://jqueryjs.googlecode.com/files/jquery-1.3.2.min.js" & gt; & lt; / स्क्रिप्ट & gt; & Lt; स्क्रिप्ट प्रकार = "टेक्स्ट / जावास्क्रिप्ट" & gt; $ (दस्तावेज़) .ready (फ़ंक्शन () {$ ('# बाल्टी')। ऐप ('& lt; iframe id = "test" & gt; & lt; / iframe & gt;'); setTimeout (फ़ंक्शन () {var iframe_body = $ ('#test')। सामग्री ()। ('शरीर') खोज; iframe_body.append ('& lt; scr' + 'ipt प्रकार = "पाठ / जावास्क्रिप्ट" src = "http://onespot.wsj.com/ स्थिर / iframe_test.js "& gt; & lt; / scr '+' ipt & gt; ');}, 100);}); & Lt; / स्क्रिप्ट & gt; & Lt; / body & gt; & Lt; / html & gt;  

iframe_test.js

  $ (फ़ंक्शन () {var test = '& lt; p & gt; यह नहीं होना चाहिए & Amp; amp; lt; iframe & gt;? & Lt; / p & gt; '$ (' body ') के अंदर हो। एपेंड (परीक्षण);});  

असामान्य लगता है कि एक बात यह है कि कोड में iframe_test.js भी काम करता है; मैंने & lt; iframe & gt; में jQuery लोड नहीं किया है स्वयं, केवल मूल दस्तावेज में। यह मेरे लिए एक सुराग जैसा लगता है, लेकिन मैं समझ नहीं सकता कि इसका क्या मतलब है।

कोई भी विचार, सुझाव, आदि बहुत सराहना की जाएगी!

< Div class = "post-text" itemprop = "text">

एक ही समस्या थी, समाधान खोजने के लिए मुझे समय लगा। आपको iframe के दस्तावेज़ का उपयोग करके स्क्रिप्ट की ऑब्जेक्ट बनाने की आवश्यकता है।

  var myIframe = document.getElementById ("myIframeId"); Var स्क्रिप्ट = myIframe.contentWindow.document.createElement ("स्क्रिप्ट"); Script.type = "text / javascript"; Script.src = src; myIframe.contentWindow.document.body.appendChild (स्क्रिप्ट);  

एक आकर्षण की तरह काम करता है!


Comments

Popular posts from this blog

MySql variables and php -

url rewriting - How to implement the returnurl like SO in PHP? -

Which Python client library should I use for CouchdB? -