From 8109e44577e49524da83139287d54b2bc83ac2a1 Mon Sep 17 00:00:00 2001 From: Evan You Date: Thu, 2 Nov 2017 16:55:05 -0400 Subject: [PATCH] fix: special case for static muted attribute in firefox fix #6887 --- src/compiler/parser/index.js | 7 +++++++ test/ssr/ssr-string.spec.js | 9 +++++++++ test/unit/modules/compiler/parser.spec.js | 9 +++++++++ 3 files changed, 25 insertions(+) diff --git a/src/compiler/parser/index.js b/src/compiler/parser/index.js index cba12d1cd4..c4554dbbec 100644 --- a/src/compiler/parser/index.js +++ b/src/compiler/parser/index.js @@ -556,6 +556,13 @@ function processAttrs (el) { } } addAttr(el, name, JSON.stringify(value)) + // #6887 firefox doesn't update muted state if set via attribute + // even immediately after element creation + if (!el.component && + platformMustUseProp(el.tag, el.attrsMap.type, name) && + name === 'muted') { + addProp(el, name, 'true') + } } } } diff --git a/test/ssr/ssr-string.spec.js b/test/ssr/ssr-string.spec.js index e52d34ffe5..60c801fab0 100644 --- a/test/ssr/ssr-string.spec.js +++ b/test/ssr/ssr-string.spec.js @@ -1000,6 +1000,15 @@ describe('SSR: renderToString', () => { done() }) }) + + it('render muted properly', done => { + renderVmWithOptions({ + template: '' + }, result => { + expect(result).toContain('') + done() + }) + }) }) function renderVmWithOptions (options, cb) { diff --git a/test/unit/modules/compiler/parser.spec.js b/test/unit/modules/compiler/parser.spec.js index c2bb6c2512..c06ac5ba2f 100644 --- a/test/unit/modules/compiler/parser.spec.js +++ b/test/unit/modules/compiler/parser.spec.js @@ -395,6 +395,15 @@ describe('parser', () => { expect(ast.props[0].value).toBe('msg') }) + // #6887 + it('special case static attribute that must be props', () => { + const ast = parse('', baseOptions) + expect(ast.attrs[0].name).toBe('muted') + expect(ast.attrs[0].value).toBe('""') + expect(ast.props[0].name).toBe('muted') + expect(ast.props[0].value).toBe('true') + }) + it('attribute with v-on', () => { const ast = parse('', baseOptions) expect(ast.events.input.value).toBe('onInput')