admin管理员组

文章数量:1346283

I've got a page full of links to another page with anchors on the end (like this: index.html#anchor). On the page they point to, I have a script that is supposed to read where the anchor points to in order to display something.

On firefox it works perfectly, But I've noticed that IE seems to remove the #anchor from the end of the url, so the script can't grab the text. Is there a way around this, without any server side code?

I've got a page full of links to another page with anchors on the end (like this: index.html#anchor). On the page they point to, I have a script that is supposed to read where the anchor points to in order to display something.

On firefox it works perfectly, But I've noticed that IE seems to remove the #anchor from the end of the url, so the script can't grab the text. Is there a way around this, without any server side code?

Share Improve this question asked Apr 29, 2010 at 23:37 tominatedtominated 3811 gold badge3 silver badges6 bronze badges
Add a ment  | 

5 Answers 5

Reset to default 5

How is it getting the url?

window.location.hash should contain the contents of the hash.

I've tested the following code in IE 6, 7, and 8, and the correct hash is shown in the alert box in all cases.

<script type="text/javascript">

    function showHash() {
        var currentUrl = "" + document.location;
        var hash = "";
        var parts = currentUrl.split("#");
        if (parts.length > 1) {
            hash = parts[1];
        }
        alert("the current hash is: " + hash);
    }

</script>

<input type="button" value="Show Hash" onclick="javascript: showHash();" />

Does that code work for you?

Does window.location still contain the anchor on IE, or is it removed there also? If it's still there you could use window.location and split on the hash:

var whole = "" + window.location;  // location is object, make sure it's a String
var parts = whole.split('#');
var anchor = parts[1];

Just try like this

    var url = window.location.search.substring(1)
    var arr=url.split("#")
    str=arr[1]

Here's a function that helps. It returns null if there's no anchor. I placed it inside an Util.js, it es in handy :D

function getAnchor() {
    var currentUrl = document.URL,
        urlParts   = currentUrl.split('#');

    return (urlParts.length > 1) ? urlParts[1] : null;
}

本文标签: javascriptReading URL Anchor on IEStack Overflow