vue.config.JS error cannot set property “preservewhitespace” of undefined
Recently, the webpack
has been configured in the project. Because vue-cli4
needs to be in Vue config.JS
file to complete the relevant configuration, so based on the principle of not making wheels, I went to the online CV method directly, but I found some problems in practice, and reported an error when the project was started cannot set property "preservewhitespace" of undefined
module.exports = {
lintOnSave:false,
chainWebpack: (config) =>{
config.module
.rule('vue')
.test( /\.vue$/)
.use('vue-loader')
.tap((options) =>{
options.compilerOptions.preserveWhitespace = true
}
)
}
}
data:image/s3,"s3://crabby-images/c13d4/c13d4ced7cdfa99d7e373608532a4420df54520e" alt=""
Print out the options option and find that there is no complier options option:
data:image/s3,"s3://crabby-images/b975a/b975a3394b8b4a98e7293fa91b9e115edda431f0" alt=""
Because the Vue loader I configured here can’t be solved after surfing the Internet for an afternoon, and even some people have made such errors, I pointed the solution to the problem to the document. In the Vue loader document, I saw the option compileroptions
:
data:image/s3,"s3://crabby-images/440f5/440f52dcefcc1dbcbfdacad28699c7b217f84125" alt=""
Good guy, this option is empty by default, so we can’t add it directly below, so we modified the code:
const addOptions = {
preserveWhitespace: true
}
module.exports = {
lintOnSave:false,
chainWebpack: (config) =>{
config.module
.rule('vue')
.test( /\.vue$/)
.use('vue-loader')
.tap((options) =>{
options.compilerOptions = addOptions
console.log(options)
}
)
}
}
Let’s print the Options
options to see if they are added:
data:image/s3,"s3://crabby-images/fa3ca/fa3ca9d3dc3db19b497c5b10dd751a81334b94b4" alt=""
We can see that the options are added and the project starts normally. If you encounter similar problems, this option may be empty and cannot be added directly.