자바스크립트로 URL 구문 분석
자바스크립트(jQuery)로 URL을 파싱하려면 어떻게 해야 합니까?
예를 들면 제 끈에 이런 게 있는데,
url = "http://example.com/form_image_edit.php?img_id=33"
나는 가치를 얻고 싶습니다.img_id
PHP로 쉽게 할 수 있다는 것을 알고 있습니다.parse_url()
, 하지만 자바스크립트로 어떻게 가능한지 알고 싶습니다.
당신은 다음과 같은 방법을 사용할 수 있습니다.a
-element, 여기에 url을 추가한 후 Location 객체를 사용합니다.
function parseUrl( url ) {
var a = document.createElement('a');
a.href = url;
return a;
}
parseUrl('http://example.com/form_image_edit.php?img_id=33').search
출력되는 항목:?img_id=33
php.js를 사용하여 자바스크립트에서 parse_url 함수를 얻을 수도 있습니다.
업데이트(2012-07-05)
초간단 URL 처리 이상의 작업이 필요하다면 우수한 URI.js 라이브러리를 사용하는 것을 추천합니다.
문자열이 호출된 경우s
그리고나서
var id = s.match(/img_id=([^&]+)/)[1]
당신에게 줄 겁니다.
시도해 보기:
var url = window.location;
var urlAux = url.split('=');
var img_id = urlAux[1]
라이너 하나:
location.search.replace('?','').split('&').reduce(function(s,c){var t=c.split('=');s[t[0]]=t[1];return s;},{})
기존의 좋은 jQuery 플러그인 Purl(자바스크립트 URL 파서).이 유틸리티는 jQuery를 사용하거나 사용하지 않는 두 가지 방식으로 사용할 수 있습니다.
구글에서 구합니다. 이 방법을 사용해보세요.
function getQuerystring2(key, default_)
{
if (default_==null)
{
default_="";
}
var search = unescape(location.search);
if (search == "")
{
return default_;
}
search = search.substr(1);
var params = search.split("&");
for (var i = 0; i < params.length; i++)
{
var pairs = params[i].split("=");
if(pairs[0] == key)
{
return pairs[1];
}
}
return default_;
}
이를 통해 코비의 답변에서 몇 가지 문제점을 해결할 수 있을 것입니다.
function getQueryParam(url, key) {
var queryStartPos = url.indexOf('?');
if (queryStartPos === -1) {
return;
}
var params = url.substring(queryStartPos + 1).split('&');
for (var i = 0; i < params.length; i++) {
var pairs = params[i].split('=');
if (decodeURIComponent(pairs.shift()) == key) {
return decodeURIComponent(pairs.join('='));
}
}
}
getQueryParam('http://example.com/form_image_edit.php?img_id=33', 'img_id');
// outputs "33"
javascript url parsing library, URL.js를 작성하였으니 이에 사용하시면 됩니다.
예:
url.parse("http://mysite.com/form_image_edit.php?img_id=33").get.img_id === "33"
이런 것이 당신에게 효과가 있을 겁니다.쿼리 문자열 값이 여러 개 있더라도 이 함수는 원하는 키의 값을 반환해야 합니다.
function getQSValue(url)
{
key = 'img_id';
query_string = url.split('?');
string_values = query_string[1].split('&');
for(i=0; i < string_values.length; i++)
{
if( string_values[i].match(key))
req_value = string_values[i].split('=');
}
return req_value[1];
}
jquery 플러그인 http://plugins.jquery.com/url 을 사용할 수 있습니다.$.url("?img_id")
돌아올 것입니다33
function parse_url(str, component) {
// discuss at: http://phpjs.org/functions/parse_url/
// original by: Steven Levithan (http://blog.stevenlevithan.com)
// reimplemented by: Brett Zamir (http://brett-zamir.me)
// input by: Lorenzo Pisani
// input by: Tony
// improved by: Brett Zamir (http://brett-zamir.me)
// note: original by http://stevenlevithan.com/demo/parseuri/js/assets/parseuri.js
// note: blog post at http://blog.stevenlevithan.com/archives/parseuri
// note: demo at http://stevenlevithan.com/demo/parseuri/js/assets/parseuri.js
// note: Does not replace invalid characters with '_' as in PHP, nor does it return false with
// note: a seriously malformed URL.
// note: Besides function name, is essentially the same as parseUri as well as our allowing
// note: an extra slash after the scheme/protocol (to allow file:/// as in PHP)
// example 1: parse_url('http://username:password@hostname/path?arg=value#anchor');
// returns 1: {scheme: 'http', host: 'hostname', user: 'username', pass: 'password', path: '/path', query: 'arg=value', fragment: 'anchor'}
var query, key = ['source', 'scheme', 'authority', 'userInfo', 'user', 'pass', 'host', 'port',
'relative', 'path', 'directory', 'file', 'query', 'fragment'
],
ini = (this.php_js && this.php_js.ini) || {},
mode = (ini['phpjs.parse_url.mode'] &&
ini['phpjs.parse_url.mode'].local_value) || 'php',
parser = {
php: /^(?:([^:\/?#]+):)?(?:\/\/()(?:(?:()(?:([^:@]*):?([^:@]*))?@)?([^:\/?#]*)(?::(\d*))?))?()(?:(()(?:(?:[^?#\/]*\/)*)()(?:[^?#]*))(?:\?([^#]*))?(?:#(.*))?)/,
strict: /^(?:([^:\/?#]+):)?(?:\/\/((?:(([^:@]*):?([^:@]*))?@)?([^:\/?#]*)(?::(\d*))?))?((((?:[^?#\/]*\/)*)([^?#]*))(?:\?([^#]*))?(?:#(.*))?)/,
loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/\/?)?((?:(([^:@]*):?([^:@]*))?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/ // Added one optional slash to post-scheme to catch file:/// (should restrict this)
};
var m = parser[mode].exec(str),
uri = {},
i = 14;
while (i--) {
if (m[i]) {
uri[key[i]] = m[i];
}
}
if (component) {
return uri[component.replace('PHP_URL_', '')
.toLowerCase()];
}
if (mode !== 'php') {
var name = (ini['phpjs.parse_url.queryKey'] &&
ini['phpjs.parse_url.queryKey'].local_value) || 'queryKey';
parser = /(?:^|&)([^&=]*)=?([^&]*)/g;
uri[name] = {};
query = uri[key[12]] || '';
query.replace(parser, function($0, $1, $2) {
if ($1) {
uri[name][$1] = $2;
}
});
}
delete uri.source;
return uri;
}
var url = window.location;
var urlAux = url.split('=');
var img_id = urlAux[1]
나를 위해 일했습니다.그러나 첫 번째 var는 varurl = window.location.href여야 합니다.
Web Workers는 url 구문 분석을 위한 utils URL을 제공합니다.
언급URL : https://stackoverflow.com/questions/6644654/parse-an-url-in-javascript
'programing' 카테고리의 다른 글
MySQL을 시작할 때 "스토리지 엔진으로 'InnoDB' 등록 실패" 오류가 발생합니다. (0) | 2023.10.20 |
---|---|
WordPress의 custom wp_query 페이지에 페이지를 지정하면 404 오류 페이지가 발생합니다. (0) | 2023.10.20 |
Android 푸시 알림:알림에 표시되지 않는 아이콘, 대신 흰색 사각형이 표시됨 (0) | 2023.10.20 |
Angularjs - 지시 파일을 분리하지만 동일한 모듈에 유지 (0) | 2023.10.20 |
자바스크립트 스크롤To 메서드가 아무 것도 하지 않습니까? (0) | 2023.10.20 |