Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Disable Browser Window Resize

For starters... I have no sinister intention of subjecting users to popups or anything like that. I simply want to prevent a user from resizing the browser window of a webpage to which they've already navigated (meaning I don't have access to / don't want to use window.open();). I've been researching this for quite a while and can't seem to find a straightforward answer.

I felt like I was on track with something along the lines of:

 $(window).resize(function() {
     var wWidth = window.width,
     wHeight = window.height;
     window.resizeBy(wWidth, wHeight);
 });

...to no avail. I have to imagine this is possible. Is it? If so, I would definitely appreciate the help.

Thanks

like image 736
Matt Rose Avatar asked May 16 '12 01:05

Matt Rose


People also ask

How do I stop web pages from resizing?

Specifying a min-width to your <body> element will prevent auto-resizing.

How do I stop chrome from resizing?

If you are using a Windows Computer you can adjust the re-sizing by right-clicking on the Chrome Shortcut to access Properties. From the Properties menu go to Compatibility tab. From there you will see a Disability display 'Disable display scaling on high DPI' option. Ensure that box is selected.

How do I stop resizing?

You simply use: resize: none; in your CSS.


2 Answers

You can first determine a definite size.

var size = [window.width,window.height];  //public variable

Then do this:

$(window).resize(function(){
    window.resizeTo(size[0],size[1]);
});

Demo: http://jsfiddle.net/DerekL/xeway917/


Q: Won't this cause an infinite loop of resizing? - user1147171

Nice question. This will not cause an infinite loop of resizing. The W3C specification states that resize event must be dispatched only when a document view has been resized. When the resizeTo function try to execute the second time, the window will have the exact same dimension as it just set, and thus the browser will not fire the resize event because the dimensions have not been changed.

like image 136
Derek 朕會功夫 Avatar answered Oct 31 '22 11:10

Derek 朕會功夫


I needed to do this today (for a panel opened by a chrome extension) but I needed to allow the user to change the window height, but prevent them changing the window width

@Derek's solution got me almost there but I had to tweak it to allow height changes and because of that, an endless resizing loop was possible so I needed to prevent that as well. This is my version of Dereck's answer that is working quite well for me:

var couponWindow = {
  width: $(window).width(),
  height: $(window).height(),
  resizing: false
};
var $w=$(window);
$w.resize(function() {
  if ($w.width() != couponWindow.width && !couponWindow.resizing) {
    couponWindow.resizing = true;
    window.resizeTo(couponWindow.width, $w.height());
  }
  couponWindow.resizing = false;
});
like image 2
Wesley Smith Avatar answered Oct 31 '22 10:10

Wesley Smith