code que j'ai trouve sur internet (j'ai juste ajoute le step a 15 -pour ton cas- )
	
	<div id="right_panel"></div>
 
	
	| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 
 | #right_panel {
    position: absolute;
    width: 96px;
    padding-left: 4px;
    height: 100%;
    right: 0;
    background-color: #f0f0ff;
}
 
#right_panel::after {
    content: '';
    background-color: #ccc;
    position: absolute;
    left: 0;
    width: 4px;
    height: 100%;
    cursor: ew-resize;
} | 
 
	
	| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 
 | const BORDER_SIZE = 4;
const STEP = 15;
const panel = document.getElementById("right_panel");
 
let m_pos;
function resize(e){
  const dx = m_pos - e.x;
  if(dx%STEP !== 0) {
  	return;
  }
  m_pos = e.x;
  panel.style.width = (parseInt(getComputedStyle(panel, '').width) + dx) + "px";
}
 
panel.addEventListener("mousedown", function(e){
  if (e.offsetX < BORDER_SIZE) {
    m_pos = e.x;
    document.addEventListener("mousemove", resize, false);
  }
}, false);
 
document.addEventListener("mouseup", function(){
    document.removeEventListener("mousemove", resize, false);
}, false); | 
 t'as un exemple la : jsfiddle.net/7od0bx5t/
						
					
Partager