是否可以使用JavaScript来更改页面的元标记?

TIM*_*MEX 93 javascript jquery meta-tags

如果我在头部放置一个div并显示:none,而不是使用JavaScript来显示它,这会有效吗?

编辑:

我在AJAX中加载了东西.当我的AJAX更改网站的"主要"部分时,我也想更改元标记.

fux*_*xia 157

是的,你可以这样做.

有一些有趣的用例:一些浏览器和插件解析元元素并改变它们对不同值的行为.

例子

Skype:关闭电话号码解析器

<meta name="SKYPE_TOOLBAR" content="SKYPE_TOOLBAR_PARSER_COMPATIBLE">
Run Code Online (Sandbox Code Playgroud)

iPhone:关闭电话号码解析器

<meta name="format-detection" content="telephone=no">
Run Code Online (Sandbox Code Playgroud)

谷歌Chrome框架

<meta http-equiv="X-UA-Compatible" content="chrome=1">
Run Code Online (Sandbox Code Playgroud)

移动设备的视口定义

<meta name="viewport" content="width=device-width, initial-scale=1.0">
Run Code Online (Sandbox Code Playgroud)

这个可以通过JavaScript更改.请参阅:修复iPhone视口规模错误

元描述

某些用户代理(例如Opera)使用书签描述.您可以在此处添加个性化内容.例:

<!DOCTYPE html>
<title>Test</title>
<meta name="description" content="this is old">
<script type='text/javascript' src='http://code.jquery.com/jquery-1.8.2.js'></script>

<button>Change description</button>

<script type='text/javascript'>
$('button').on('click', function() {
    // Just replacing the value of the 'content' attribute will not work.
    $('meta[name=description]').remove();
    $('head').append( '<meta name="description" content="this is new">' );
});
</script>
Run Code Online (Sandbox Code Playgroud)

所以,它不只是关于搜索引擎.

  • 我怀疑像这样的大多数元素具有在页面加载后不可更改的效果.但是,是的,元不仅仅是"关键字"和"描述". (9认同)
  • @bobince:实际上,如果你用js插入它,SKYPE_TOOLBAR仍然会生效(这很有用,因为html5验证器不喜欢那个元标记). (2认同)
  • 您可以以此做一些很酷的事情。当标题中的幻灯片更改时,我更改了Chrome地址栏的颜色。`const meta = document.querySelector('meta [name = theme-color]'); meta.setAttribute(“ content”,colors [slideIndex]);`Android上的Chrome会检测到更新并更改颜色 (2认同)

jay*_*yms 109

是的.

例如,设置元描述:

document.querySelector('meta[name="description"]').setAttribute("content", _desc);
Run Code Online (Sandbox Code Playgroud)

  • 感谢您提供没有jQuery的解决方案 (20认同)
  • 很高兴有人用纯粹的js给出答案(按照问题的要求)! (17认同)
  • 看来您需要查询 `property` 属性,而不是 `name` 属性,即 `meta[property="og:title"]` (2认同)

Mif*_*Fox 66

你会使用类似的东西(使用jQuery):

$('meta[name=author]').attr('content', 'New Author Name');
Run Code Online (Sandbox Code Playgroud)

但这通常是毫无意义的,因为元标记通常只在加载文档时被抓取,通常不会执行任何JavaScript.

  • 它甚至适用于选择器,例如`$('meta [property = og:somestuff]')`,我怀疑它会因为冒号而与jQuery选择语法冲突. (7认同)
  • 如果其他人正在寻找这个确切的解决方案,你需要在og周围加上引号:somestuff - 我需要图片标签的内容,这是我的代码:var imgurl = $("meta [property ='og:image "]内容") ")ATTR("; (7认同)
  • 确认它适用于元视口设置(需要这个来启用/禁用jQuery Mobile上某些子页面的缩放).谢谢! (2认同)

小智 34

您可以使用例如jQuery调用来更改元数据,如下所示:

$('meta[name=keywords]').attr('content', new_keywords);
$('meta[name=description]').attr('content', new_description);
Run Code Online (Sandbox Code Playgroud)

我认为这确实重要,现在,因为谷歌表示,他们将通过指数的Ajax内容#!hashes_escaped_fragment_电话.现在他们可以验证它(甚至自动,无头浏览器,请参阅上面提到的页面上的'创建HTML快照'链接),所以我认为这是硬核SEO人员的方式.

  • 实际上,现在谷歌也可以运行javascript,无需创建页面快照,所以现在动态元标签确实很重要! (4认同)
  • 这次真是万分感谢.刚刚解决了我的问题.因为facebook有开放图表.我正在开发的网站有一个History jQuery插件和哈希标签.因此,当存在散列更改时,需要更改FB打开的图形URL和描述.+1是一个很好的答案,而不是对一个公平的问题负面. (3认同)

Tim*_*ses 22

绝对可以使用Javascript来更改页面的元标记.这是一个仅限Javascript的方法:

document.getElementsByTagName('meta')["keywords"].content = "My new page keywords!!";
document.getElementsByTagName('meta')["description"].content = "My new page description!!";
document.title = "My new Document Title!!";
Run Code Online (Sandbox Code Playgroud)

我已经确认Google确实为上述代码编制了这些客户端更改的索引.

  • 有趣的!感谢您让我了解 `element = collection[name]` 语法。 (4认同)

fut*_*tta 11

元标记是dom的一部分,可以被访问和-i猜测 - 但是搜索引擎(元标记的主要消费者)将不会看到更改,因为javascript将不会被执行.所以,除非你正在改变一个在浏览器中有影响的元标记(刷新想到),这可能没什么用处?

  • +1 - 我登陆这个问题,因为我特别想知道元刷新.我正在创建一个应用程序,它使用ajax轮询来刷新屏幕上的数据,我想为没有启用javascript的浏览器提供粗略的回退.我想我可以通过默认创建元刷新标记来实现这一点,如果启用了javascript,只需删除元标记即可. - 现在看看它是否真的有效...... (3认同)

Mik*_*son 11

应该可以这样(或使用jQuery $('meta[name=author]').attr("content");):

<html>
<head>
<title>Meta Data</title>
<meta name="Author" content="Martin Webb">
<meta name="Author" content="A.N. Other">
<meta name="Description" content="A sample html file for extracting meta data">
<meta name="Keywords" content="JavaScript, DOM, W3C">

</head>

<body>
<script language="JavaScript"><!--
if (document.getElementsByName) {
  var metaArray = document.getElementsByName('Author');
  for (var i=0; i<metaArray.length; i++) {
    document.write(metaArray[i].content + '<br>');
  }

  var metaArray = document.getElementsByName('Description');
  for (var i=0; i<metaArray.length; i++) {
    document.write(metaArray[i].content + '<br>');
  }

  var metaArray = document.getElementsByName('Keywords');
  for (var i=0; i<metaArray.length; i++) {
    document.write(metaArray[i].content + '<br>');
  }
}
//--></script>
</body>

</html>
Run Code Online (Sandbox Code Playgroud)


Ali*_*ahi 11

您可以使用更简单、更轻便的解决方案:

document.head.querySelector('meta[name="description"]').content = _desc
Run Code Online (Sandbox Code Playgroud)


小智 10

$(document).ready(function() {
  $('meta[property="og:title"]').remove();
  $('meta[property="og:description"]').remove();
  $('meta[property="og:url"]').remove();
  $("head").append('<meta property="og:title" content="blubb1">');
  $("head").append('<meta property="og:description" content="blubb2">');
  $("head").append('<meta property="og:url" content="blubb3">');
});
Run Code Online (Sandbox Code Playgroud)

  • 我从你的例子开始,但意识到你不必删除并重新添加元标记.您可以像这样更改content-attribute:`jQuery('meta [property ="og:title"]').attr('content',"blubb1");` (6认同)

Yo7*_*hik 7

name 属性允许您通过子元素列表通过名称(如 id)引用元素,所以快速方法是:

\n
document.head.children.namedItem('description').content = '...'\n
Run Code Online (Sandbox Code Playgroud)\n

\xe2\x80\x94 甚至只是:

\n
document.head.children.description.content = '...'\n
Run Code Online (Sandbox Code Playgroud)\n

但如果您不确定这样的元标记是否存在,那么最好添加如下检查:

\n
let metaDescription = document.head.children.description\nif (metaDescription == null) {\n  metaDescription = document.createElement('meta')\n  metaDescription.name = 'description'\n  document.head.append(metaDescription)\n}\nmetaDescription.content = '...'\n
Run Code Online (Sandbox Code Playgroud)\n


小智 5

var metaTag = document.getElementsByTagName('meta');
for (var i=0; i < metaTag.length; i++) {
    if (metaTag[i].getAttribute("http-equiv")=='refresh')
        metaTag[i].content = '666';
    if (metaTag[i].getAttribute("name")=='Keywords')
        metaTag[i].content = 'js, solver';
}
Run Code Online (Sandbox Code Playgroud)


Jor*_*cio 5

对于任何试图更改 og:title 元标记(或任何其他标记)的人。我设法这样做:

document.querySelector('meta[property="og:title"]').setAttribute("content", "Example with og title meta tag");
Run Code Online (Sandbox Code Playgroud)

请注意,“meta[property="og:title"]”包含单词“PROPERTY”,而不是“NAME”。


Ben*_*Ben 1

不,div 是 body 元素,而不是 head 元素

编辑:那么 SE 唯一能得到的是基本 HTML,而不是 ajax 修改后的 HTML。