以可在浏览器中执行的方式用 Javascript 替换 HTML
我根本没有 JavaScript 经验。我想要的是替换页面 HTML 中文本块的单个实例 - 我该如何做到这一点?
30 分钟的阅读让我意识到:
javascript:document.body.innerHTML = document.body.innerHTML.replace("this","that");
我已经接近了吗?
I have no Javascript experience at all. What I want is to replace a single instance of a block of text in a page's HTML - how can I do this?
30 minutes of reading around has brought me this:
javascript:document.body.innerHTML = document.body.innerHTML.replace("this","that");
Am I even close?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
由于没有任何经验,我建议您看一下 jQuery。使用 jQuery,您可以执行以下操作:
给定:
jQuery:
With no experiance at all I recommend you take a look at jQuery. With jQuery you can do:
Given:
jQuery:
1) 如果它是 URL 的一部分,例如
,那么您需要
javascript:void(document.body.innerHTML = document.body.innerHTML.replace("this","that"));
2) 如果它是事件的一部分,例如
3) 如果您尝试将“this”的所有实例替换为“that”,并且不仅仅是第一个,那么你需要
....replace(/this/g,"that")
1) If it is part of a URL, such as
<a href="...">
, then you needjavascript:void(document.body.innerHTML = document.body.innerHTML.replace("this","that"));
2) If it is part of an event, such as
<button onClick="...">
, then you needdocument.body.innerHTML = document.body.innerHTML.replace("this","that");
3) If you are trying to replace ALL instances of "this" with "that", and not just the first, then you need
... .replace(/this/g,"that")
您不能只在地址栏中执行该脚本。它需要对一个文档进行操作,但是那里没有任何东西可以替代。从地址栏执行 javascript 将为您提供一个新的空文档,该代码将在该文档上运行。
即使您尝试从 JavaScript 加载文档,脚本的其余部分也会首先执行。试试这个:
您会看到在页面加载之前弹出警报,并且显示“未定义”。
即使您尝试绑定到文档或窗口的 onload 事件,它也不会起作用。可能是因为它们之后被重置。
这是有道理的;如果这可行,您可以在跳转到下一个页面时操作该页面,从而可以在链接到的页面中注入 javascript。这将是一个很大的安全问题,所以这是一件好事,这不起作用。
You cannot just execute that script in the address bar. It needs to operate on a document, but there is nothing to replace there. Executing javascript from the address bar will give you a new empty document on which that code operates.
Even if you try to load a document from javascript, the rest of your script gets executed first. Try this:
You'll see that the alert pops up before the page is loaded, and it shows 'undefined'.
Even when you try binding to the onload event of the document or the window it won't work. Probably because they are reset afterwards.
And it makes sense; if this would work, you could manipulate the next page when jumping to that page, thus making it possible to inject javascript in a page you link to. That would be a big security issue, so it's a good thing this doesn't work.