Problem With List Views That Exceeds Browser Window Width
This post is over a year old, some of this information may be out of date.
Last week a customer indicated that layout problems could arise with list views. The problem arises when the amount of data/columns that is visible, exceeds the browser width. This creates an empty space next to the title row when the user scrolls horizontally.

This problem occurs when loading the page, the JavaScript of SharePoint sets the browser window width to the title row element.
After some research I found two solution to set the width of the list view to the title row.

Solution 1
The first solution is a CSS based and works only for IE 8, FF and Chrome. Add the following CSS code to a custom stylesheet.
#s4-workspace { position: relative;}#s4-bodyContainer { position: absolute;}
Solution 2
This solution makes use of some JavaScript to set the correct width to the title row. This solution works on IE 7, IE 8, FF, and Chrome.
The code will check if the list view width and when it is wider than the browser window width, the list view width is set to the title row.
In the code I added an array of elements to which the width needs to be set when the list view is too wide. The standard elements to which the width needs to be assigned to are the top navigation section (#s4-topheader2) and the site description section (.s4-title).
This solution also works when using my footer solution. You will just need to add the “.footer” element to the JavaScript array.
<script type="text/javascript" src="jquery.min.js"></script><script> $(function() { //Retrieve the width from list view table var tableWidth = parseInt($("#WebPartWPQ2").width());
if(tableWidth > parseInt($("body").width())) { //Retrieve the left margin for the quicklaunch var leftMargin = $("#MSO_ContentTable").css("margin-left").replace("px", ""); var newSize = tableWidth + parseInt(leftMargin);
//Array with the elements that need to get the new width var elmArray = new Array("#s4-topheader2",".s4-title");
var arLen = elmArray.length; //Loop over each array element for ( var i = 0, len = arLen; i < len; ++i ){ //Get the left padding size var leftPadding = parseInt($(elmArray[i]).css("padding-left").replace("px", "")); //Set the correct width to the element $(elmArray[i]).width(newSize - leftPadding ); } } });</script>
Related articles
Report issues or make changes on GitHub
Found a typo or issue in this article? Visit the GitHub repository to make changes or submit a bug report.
Comments
Let's build together
Manage content in VS Code
Present from VS Code