@advdominion/get-scrollbar-width
This commit is contained in:
17
packages/get-scrollbar-width/README.md
Normal file
17
packages/get-scrollbar-width/README.md
Normal file
@@ -0,0 +1,17 @@
|
||||
# get-scrollbar-width
|
||||
|
||||
Get window scrollbar width (if present):
|
||||
|
||||
```js
|
||||
import { getScrollbarWidth } from '@advdominion/get-scrollbar-width';
|
||||
|
||||
console.log(getScrollbarWidth());
|
||||
```
|
||||
|
||||
Get system scrollbar width:
|
||||
|
||||
```js
|
||||
import { getScrollbarWidth } from '@advdominion/get-scrollbar-width';
|
||||
|
||||
console.log(getScrollbarWidth(false));
|
||||
```
|
24
packages/get-scrollbar-width/index.js
Normal file
24
packages/get-scrollbar-width/index.js
Normal file
@@ -0,0 +1,24 @@
|
||||
const scrollbarWidth = () => {
|
||||
const outer = document.createElement('div');
|
||||
outer.style.visibility = 'hidden';
|
||||
outer.style.width = '100px';
|
||||
document.body.append(outer);
|
||||
const widthNoScroll = outer.offsetWidth;
|
||||
outer.style.overflow = 'scroll';
|
||||
const inner = document.createElement('div');
|
||||
inner.style.width = '100%';
|
||||
outer.append(inner);
|
||||
const widthWithScroll = inner.offsetWidth;
|
||||
outer.remove();
|
||||
return widthNoScroll - widthWithScroll;
|
||||
};
|
||||
|
||||
export const getScrollbarWidth = (getWindowScrollbar = true) => {
|
||||
if (getWindowScrollbar) {
|
||||
if (document.body.clientHeight > window.innerHeight) {
|
||||
return scrollbarWidth();
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
return scrollbarWidth();
|
||||
};
|
14
packages/get-scrollbar-width/package.json
Normal file
14
packages/get-scrollbar-width/package.json
Normal file
@@ -0,0 +1,14 @@
|
||||
{
|
||||
"name": "@advdominion/get-scrollbar-width",
|
||||
"version": "1.1.0",
|
||||
"type": "module",
|
||||
"main": "index.js",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://gitea.optiweb.ru/public/helpers.git"
|
||||
},
|
||||
"license": "MIT",
|
||||
"publishConfig": {
|
||||
"access": "public"
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user