美文网首页
解决vue ssr css内联样式和link标签重复问题

解决vue ssr css内联样式和link标签重复问题

作者: redpeanuts | 来源:发表于2020-09-06 14:15 被阅读0次

基于vue-cli3的项目,改造成SSR。
服务端渲染会提取组件的样式内联到html中,与link标签中的重复,使得页面体积变大,导致响应时间很慢。
原因是ssr会自动进行资源注入Manual Asset Injection,包含css、js等。

我们需要的是没有<style>标签的页面

所以通过配置参数,关闭资源注入。

//server.js
//创建bundlerender

function createRenderer(bundle, options) {
  return createBundleRenderer(
    bundle,
    Object.assign(options, {
      basedir: resolve('./dist'),
      inject: false,
    })
  )
}

接下来需要把css、js等文件再关联到输出的html中
当创建bundlerender的时候,我们可以使用一个模板,在这个模板里面预置页面所需要的各种资源。

//服务端渲染用到的模板
  const templatePath = resolve('./dist/index.ssr.html')
  const template = fs.readFileSync(templatePath, 'utf-8')
  const bundle = require('./dist/vue-ssr-server-bundle.json')
  // The client manifests are optional, but it allows the renderer
  // to automatically infer preload/prefetch links and directly add <script>
  // tags for any async chunks used during render, avoiding waterfall requests.
  const clientManifest = require('./dist/vue-ssr-client-manifest.json')
  renderer = createRenderer(bundle, {
    template,
    clientManifest,
  })

思来想去,csr(客户端渲染)模式下生成的index.html再合适不过了。
而且,当build csr时,我们也可以预置一个模板,在这里添加上第三方的资源

--/public
----index.html

最后是在模板中添加锚点

const fs = require('fs')

fs.readFile('./dist/index.html', 'utf8', (err, data) => {
//替换锚点
  data = data.replace('<div id=app></div>', '<!--vue-ssr-outlet-->')
  fs.writeFile('./dist/index.ssr.html', data, (err) => {
    if (err) throw err
    console.log('The file has been saved!')
  })
})

到这里基本大功告成

总结

  • 模板预置页面所需资源
  • 关闭ssr资源自动注入

贴一下vue.config.js和build script(windows 平台)

//vue.config.js

const VueSSRServerPlugin = require('vue-server-renderer/server-plugin')
const VueSSRClientPlugin = require('vue-server-renderer/client-plugin')
const merge = require('lodash.merge')
const TARGET_NODE = process.env.WEBPACK_TARGET === 'node'
const target = TARGET_NODE ? 'server' : 'client'

module.exports = {
  configureWebpack: () => ({
    entry: `./src/entry-${target}.js`,
    target: TARGET_NODE ? 'node' : 'web',
    node: TARGET_NODE ? undefined : false,
    output: {
      libraryTarget: TARGET_NODE ? 'commonjs2' : undefined,
    },
    optimization: {
      splitChunks: false,
    },
    plugins: [
      TARGET_NODE ? new VueSSRServerPlugin() : new VueSSRClientPlugin(),
    ],
  }),
  chainWebpack: (config) => {
    config.module
      .rule('vue')
      .use('vue-loader')
      .tap((options) => {
        merge(options, {
          optimizeSSR: false,
        })
      }),
      config.plugin('VuetifyLoaderPlugin').tap((args) => [
        {
          match(originalTag, { kebabTag, camelTag, path, component }) {
            if (kebabTag.startsWith('core-')) {
              return [
                camelTag,
                `import ${camelTag} from '@/components/core/${camelTag.substring(
                  4
                )}.vue'`,
              ]
            }
          },
        },
      ])
  },
  transpileDependencies: ['vuetify'],
}
//build script
"build:client": "vue-cli-service build",
"build:server": "cross-env WEBPACK_TARGET=node vue-cli-service build --mode server",
"build:win": "npm run build:server && move dist\\vue-ssr-server-bundle.json bundle && npm run build:client && move bundle dist\\vue-ssr-server-bundle.json"

相关文章

  • 解决vue ssr css内联样式和link标签重复问题

    基于vue-cli3的项目,改造成SSR。服务端渲染会提取组件的样式内联到html中,与link标签中的重复,使得...

  • css

    引入css样式的四种方式: 内联样式(style属性) style 标签 外部文件 (CSS link) @imp...

  • css杂记

    css的引入方式 嵌入式,内联样式style标签、外部css文件link、在a.css样式中引入b.css的样式:...

  • 引入css的四种方式

    style属性内联样式 style标签 link标签引入的外部样式 将style写在.css后缀的文件里,用lin...

  • CSS总结

    引入样式方法: 内联:style属性 Style标签 外部文件 css link @import url(./b....

  • 样式表的种类和权重

    外部样式表 理想的选择 link引入 .css存储 内部样式表 文档中定义 style标签中 内联样式 慎用,内容...

  • CSS基本样式(基础中的基础)

    1.如何在页面引用 CSS 1.内联样式; 2内部引用样式; 3外部引用link标签,引用样式; 4外部引用@im...

  • 记11月29日作业

    问题一:CSS有几种引入方式? link 和@import 有什么区别? css一共有4种引入方式: 内联样式 内...

  • css优先级

    css有四种加载样式的方式:内联、syle标签、link、import。这四种方式均可以影响html的样式。假设你...

  • H5-CSS

    css样式表 css新建格式内部样式表 css语句 内联样式 引用外部样式表文件直接引用(link)

网友评论

      本文标题:解决vue ssr css内联样式和link标签重复问题

      本文链接:https://www.haomeiwen.com/subject/mkkcektx.html