2
0
mirror of https://github.com/tenrok/vue-meta.git synced 2026-06-08 07:42:25 +03:00

prevent overriding pre-existing meta tags with shared attribute names

This commit is contained in:
Declan de Wet
2016-11-04 02:55:55 +02:00
parent a6b0148f88
commit a17478c2ae
2 changed files with 38 additions and 4 deletions
+35 -1
View File
@@ -9,7 +9,41 @@ import getComponentOption from './getComponentOption'
*/
export default function getMetaInfo (component) {
// collect & aggregate all metaInfo $options
const info = getComponentOption({ component, option: 'metaInfo', deep: true })
const info = getComponentOption({
component,
option: 'metaInfo',
deep: true,
// In order to prevent certain tags from being overwritten,
// (like <meta name="description" ...> being overwritten by
// <meta name="keywords" ...>), we need to specify a different
// array merge strategy. This strategy exploits a trick
// with associative arrays in JS using O(1) lookup
/* eslint-disable no-labels */
arrayMerge (oldTags, newTags) {
const updatedTags = []
for (let oldTagIndex in oldTags) {
const oldTag = oldTags[oldTagIndex]
let sharedAttributes = false
ifTagsHaveEqualSharedAttributeValues: for (let newTagIndex in newTags) {
const newTag = newTags[newTagIndex]
for (let attribute in newTag) {
if (newTag.hasOwnProperty(attribute) && oldTag.hasOwnProperty(attribute)) {
if (oldTag[attribute] === newTag[attribute]) {
sharedAttributes = true
break ifTagsHaveEqualSharedAttributeValues
}
}
}
}
if (!sharedAttributes) {
updatedTags.push(oldTag)
}
}
return updatedTags.concat(newTags)
}
/* eslint-enable no-labels */
})
// if any info options are a function, coerce them to the result of a call
for (let key in info) {