回答:
これは、PHPコードからの直接変換です。
//Loading the variable
var mystr = '0000000020C90037:TEMP:data';
//Splitting it with : as the separator
var myarr = mystr.split(":");
//Then read the values from the array where 0 is the first
//Since we skipped the first element in the array, we start at 1
var myvar = myarr[1] + ":" + myarr[2];
// Show the resulting value
console.log(myvar);
// 'TEMP:data'
split(delimiter,limit)
の制限パラメータは、の制限パラメータと同じようには機能しませんexplode($delimiter,$string,$limit)
。例:explode('.','1.2.3.4',3) === array('1','2','3.4')
-JavaScriptでは、次のようになります'1.2.3.4'.split('.',3) === ['1', '2', '3']
。誰でも簡単にPHPのメソッドを複製する方法を知っていますか?
分割する必要はありません。あなたは使用することができますindexOf
とsubstr
:
str = str.substr(str.indexOf(':')+1);
しかし、同等にはexplode
なりますsplit
。
String.prototype.explode = function (separator, limit)
{
const array = this.split(separator);
if (limit !== undefined && array.length >= limit)
{
array.push(array.splice(limit - 1).join(separator));
}
return array;
};
PHPのexplode()関数を正確に模倣する必要があります。
'a'.explode('.', 2); // ['a']
'a.b'.explode('.', 2); // ['a', 'b']
'a.b.c'.explode('.', 2); // ['a', 'b.c']
これを試して:
arr = str.split (":");
作成のオブジェクト:
// create a data object to store the information below.
var data = new Object();
// this could be a suffix of a url string.
var string = "?id=5&first=John&last=Doe";
// this will now loop through the string and pull out key value pairs seperated
// by the & character as a combined string, in addition it passes up the ? mark
var pairs = string.substring(string.indexOf('?')+1).split('&');
for(var key in pairs)
{
var value = pairs[key].split("=");
data[value[0]] = value[1];
}
// creates this object
var data = {"id":"5", "first":"John", "last":"Doe"};
// you can then access the data like this
data.id = "5";
data.first = "John";
data.last = "Doe";
phpが好きなら、php.JS-JavaScript explodeを見てください。
または通常のJavaScript機能:
var vInputString = "0000000020C90037:TEMP:data";
var vArray = vInputString.split(":");
var vRes = vArray[1] + ":" + vArray[2]; `
emptyArray = { 0: '' }
?:-/
explode('foo','bar'); // 'bar'
これが私がここに到着した理由であり、目的のために制限付きで使用するコピーアンドペーストスクリプトは完全に完璧です。私は自分のものを作成するために傍観する必要はありません。結局のところ、ホイールを再発明するのはなぜですか、キス
console.log(('0000000020C90037:TEMP:data').split(":").slice(1).join(':'))
出力: TEMP:data
John Hartsockを批判するつもりはありませんが、特定のコードを使用している人が区切り文字の数を変える可能性がある場合に備えて、代わりにこれを使用することを正式に提案します...
var mystr = '0000000020C90037:TEMP:data';
var myarr = mystr.split(":");
var arrlen = myarr.length;
var myvar = myarr[arrlen-2] + ":" + myarr[arrlen-1];
var str = '0000000020C90037:TEMP:data'; // str = "0000000020C90037:TEMP:data"
str = str.replace(/^[^:]+:/, ""); // str = "TEMP:data"
したがって、この投稿はかなり古いことを知っていますが、私は長年にわたって私を助けてくれた関数を追加することもできると考えました。上記のように、splitを使用してexplode関数を再作成しないのはなぜですか?さてここにあります:
function explode(str,begin,end)
{
t=str.split(begin);
t=t[1].split(end);
return t[0];
}
この関数は、2つの値の間の値を取得する場合に役立ちます。例えば:
data='[value]insertdataherethatyouwanttoget[/value]';
2つの[値]「タグ」の間から情報を取得することに興味がある場合は、次のような関数を使用できます。
out=explode(data,'[value]','[/value]');
//Variable out would display the string: insertdataherethatyouwanttoget
しかし、上記の例のような便利な「タグ」が表示されていないとしましょう。どんなに。
out=explode(data,'insert','wanttoget');
//Now out would display the string: dataherethatyou
var str = "helloword~this~is~me";
var exploded = str.splice(~);
展開された変数は配列を返し、配列の要素にアクセスして、それにアクセスできますtrue expanded [nth]ここで、nthは取得する値のインデックスです
~
ます。これは、構文エラーになります。そして、スプライスはこの目的のためではなく、配列から項目を取得/取得したり、配列に追加したりするためのものです。
このようにしてみてください
ans = str.split (":");
文字列の2つの部分を使用できます。
ans [0]およびans [1]
独自の関数を定義したい場合は、これを試してください:
function explode (delimiter, string, limit) {
if (arguments.length < 2 ||
typeof delimiter === 'undefined' ||
typeof string === 'undefined') {
return null
}
if (delimiter === '' ||
delimiter === false ||
delimiter === null) {
return false
}
if (typeof delimiter === 'function' ||
typeof delimiter === 'object' ||
typeof string === 'function' ||
typeof string === 'object') {
return {
0: ''
}
}
if (delimiter === true) {
delimiter = '1'
}
// Here we go...
delimiter += ''
string += ''
var s = string.split(delimiter)
if (typeof limit === 'undefined') return s
// Support for limit
if (limit === 0) limit = 1
// Positive limit
if (limit > 0) {
if (limit >= s.length) {
return s
}
return s
.slice(0, limit - 1)
.concat([s.slice(limit - 1)
.join(delimiter)
])
}
// Negative limit
if (-limit >= s.length) {
return []
}
s.splice(s.length + limit)
return s
}