npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

webp-detect-webpack-plugin

v1.1.0

Published

webp-detect-plugin, with webpack plugin

Downloads

6

Readme

webp-detect-webpack-plugin

judge webp format can you use in browser
npm i webp-detect-webpack-plugin
// use
const BrowserDetect = require('webp-detect-webpack-plugin');

// in webpack, you can use this
// you should use the plugin in html-webpack-plugin after,
// otherwise it's will not take effect
plugins: [
  new BrowserDetect(),
],

you can transmit a option to the plugin

option is a object type, it's optional, each property default is that:

default option below

{
  // inject code into file regexp
  test: /.\.html$/,
  // compress type detect, you can use lossy lossless alpha animation
  feature = 'lossless',
  // when support webp, will inject this code
  insertCode = 'document.documentElement.setAttribute("webp", true);window.__detect_webp__ = true;',
  // when don't support webp, will add this code
  errorCode = 'document.documentElement.setAttribute("webp", false);window.__detect_webp__ = false;',
  // inject flag, you can define it, but you should add in html page
  // about insertFlag, it's should in head tag inset
  insertFlag = '<head>',
}

with set the insertCode property, in other place, you can judgement by this

const isCanUseWebp = document.documentElement.getAttribute('webp') === 'true';

or

const isCanUseWebp = window.__detect_webp__
插件支持一个对象入参,默认参数如上所示, 但你也可以更改
test 就是正则匹配到了的需要注入兼容性代码的文件
feature webp压缩格式, 有些特殊的压缩格式可能存在兼容, 默认的无损压缩
insertCode 用来在浏览器中取到的标识判断,建议不要更改, 后续其他的工具可能都会根据此来判断
errorCode 当浏览器不支持webp格式的标识代码,建议不要更改, 后续其他的工具可能都会根据此来判断
insertFlag 默认在head标签后追加, 当然你也可以在模板中定义其他占位符, 但一定要在head中靠前的位置

运行时对于支持webp格式的 window.__detect_webp__ 为true, 否则为 false