IE8ラップトップで地理位置情報を機能させるための複数のオプションが必要で、Google Chrome Frame(機能する)とjquery polyfill(機能しようとしているもの)の両方を調査しました。例が取得された Web サイトはwebshimsであり、言及されたデモ ページが IE8 で動作することを確認しましたが、自分で例を再現することはできません。これは私のjspです:
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8>
<title>Geolocation</title>
<script src="<c:url value="/js/jquery-1.6.4.min.js"/>" type="text/javascript"></script>
<script src="<c:url value="/js/modernizr-latest.js"/>" type="text/javascript"></script>
<script src="<c:url value="/js/polyfiller.js"/>" type="text/javascript"></script>
<script type="text/javascript">
//http://afarkas.github.com/webshim/demos/demos/geolocation.html
$.webshims.polyfill();
navigator.geolocation.getCurrentPosition(function(pos){ $("#status").html("found you! latitude: "+ pos.coords.latitude +"/longitude: " + pos.coords.longitude); });
</script>
</head>
<body>
<p>Finding your location: <span id="status">checking...</span></p>
</body>
</html>
地理位置情報がネイティブにサポートされているブラウザーで動作しますが、ポリフィルは IE8 では機能していないようです。以下のエラーが表示されます。
Web ページのエラーの詳細
ユーザー エージェント: Mozilla/4.0 (互換性あり; MSIE 8.0; Windows NT 5.1; Trident/4.0; chromeframe/15.0.874.121; .NET CLR 2.0.50727; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729) タイムスタンプ: 水、2011 年 12 月 7 日 17:48:06 UTC
メッセージ: 'navigator.geolocation' は null またはオブジェクトではありません 行: 13 文字: 7 コード: 0 URI: ../GeoLocation/jquery.action
この機能を適切に行うために何か不足していますか?