我正在尝试按照prefetch
Chrome Lighthouse 审计报告的建议将指令与我的字体一起使用。但是,这样做会引发以下错误:
未捕获(承诺中)错误:超过 3000 毫秒超时
我的堆栈涉及用于 SSR 的 NextJS。我的index.jsx看起来像这样:
import React, { PureComponent, Fragment } from 'react';
import Typography from '@material-ui/core/Typography';
import { withStyles } from '@material-ui/core/styles';
import Head from 'next/head';
import Link from 'next/link';
import withRoot from '../lib/withRoot';
import Fonts from '../lib/Fonts'
const styles = theme => ({
root: {
textAlign: 'center',
paddingTop: theme.spacing.unit * 20,
},
paragraph: {
fontFamily: 'Oswald',
}
});
class Index extends PureComponent {
constructor(props) {
super(props);
this.state = {
open: false,
};
}
componentDidMount() {
if ('serviceWorker' in navigator) { navigator.serviceWorker.register('/serviceWorker.js'); }
Fonts();
}
render() {
const { classes } = this.props;
const { open } = this.state; // eslint-disable-line no-unused-vars
const title = 'Home';
const description = 'This is the description for the homepage';
return (
<Fragment>
<Head>
<title>{ title }</title>
<meta name="description" content={description} key="description" />
</Head>
<div className={classes.root}>
<Typography gutterBottom>
<Link href="/blog">
<a>View posts page</a>
</Link>
</Typography>
</div>
<p className={classes.paragraph}>All men must die</p>
</Fragment>
);
}
}
export default withRoot(withStyles(styles)(Index));
Fonts.js看起来像这样:
const FontFaceObserver = require('fontfaceobserver');
const addFont = (fontUrl) => {
const fontName = fontUrl.split('=')[1].split(':')[0].split('&')[0];
const fontNameWithSpace = fontName.replace(/\+/g, ' ');
const link = document.createElement('link');
link.href = fontUrl;
link.rel = 'stylesheet';
document.head.appendChild(link);
const addedFont = new FontFaceObserver(fontNameWithSpace);
addedFont.load().then(() => {
document.documentElement.classList.add(fontName);
});
};
const Fonts = () => {
// Oswald
addFont('https://fonts.googleapis.com/css?family=Oswald:400,500,600,700&display=swap');
// Roboto
addFont('https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap');
// Source Sans Pro
addFont('https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,600&display=swap');
};
export default Fonts;
如您所见,我仅通过componentDidMount()在浏览器上运行Fonts()方法。怎么了?