首先,我对javascript的知识非常有限,所以我可能会使用的某些术语可能完全不合适,但我已尽力将其描述为最佳。
我发现了一个非常奇怪的问题...我一直在尝试编辑别人的JS脚本,因为如果他们已经编写了我自己的话,那就没有意义了得到了我想要的大部分功能。问题接近直接插入到html中的JS脚本的底部,具体是那些实际上将脚本连接到HTML代码中的ID的那些,例如" document.getElementById(" playerAdmin&# 34;)。innerHTML = playerAdmin;"。正如你所看到的那样,与其他部分相比,它相当混乱,因为我们不得不继续搞乱它,因为它们只是随机地看起来有效,所以我不得不一直搞乱订单这些东西都进去了。例如,而不是:
document.getElementById("playerID").innerHTML = playerID;
document.getElementById("playerWanted").innerHTML = wanted;
document.getElementById("playerBankMoney").innerHTML = bank;
我可能需要将它的顺序交换为:
document.getElementById("playerWanted").innerHTML = wanted;
document.getElementById("playerBankMoney").innerHTML = bank;
document.getElementById("playerID").innerHTML = playerID;
因为其中一个ID似乎不起作用 - 代码中没有任何内容告诉我为什么会发生这种情况,而且对我来说这似乎很随意 - 一般来说,似乎任何代码都在“破碎的片断”之下。 (再次,随机选择)停止运作。
function parseURLParams(url) {
var queryStart = url.indexOf("?") + 1,
queryEnd = url.indexOf("#") + 1 || url.length + 1,
query = url.slice(queryStart, queryEnd - 1),
pairs = query.replace(/\+/g, " ").split("&"),
parms = {},
i, n, v, nv;
if (query === url || query === "") return;
for (i = 0; i < pairs.length; i++) {
nv = pairs[i].split("=", 2);
n = decodeURIComponent(nv[0]);
v = decodeURIComponent(nv[1]);
if (!parms.hasOwnProperty(n)) parms[n] = [];
parms[n].push(nv.length === 2 ? v : null);
}
return parms;
}
var urlParams = parseURLParams(document.location.href);
console.log(urlParams);
&#13;
* {
margin: 0;
font-family: 'Ubuntu', sans-serif;
}
a {
text-decoration: none;
}
div.header {
width: 100%;
background-color: rgb(35, 56, 89);
height: 59px
}
div.header a {
text-decoration: none;
text-transform: capitalize;
color: white;
padding: 20px;
float: right;
transition: 0.2s;
}
div.header a:hover {
background-color: rgba(0, 0, 0, 0.1);
color: deepskyblue;
}
div.header a.active {
color: deepskyblue;
}
body {
background: url();
background-color: rgba(44, 105, 140, 0.1);
background-position: center center;
}
h1.title {
color: rgb(35, 56, 89);
text-transform: lowercase;
font-size: 5em;
text-align: center;
padding: 140px;
text-shadow: 0px 0px 21px rgba(0, 0, 0, 0.3);
}
h1.title span {
color: deepskyblue;
text-transform: uppercase;
}
div.search {
width: 80%;
height: 70px;
padding: 20px;
margin: 30px auto;
background-color: rgb(35, 56, 89);
box-shadow: 0px 0px 28px -4px rgba(0, 0, 0, 0.75);
}
div.search a {
color: deepskyblue;
text-decoration: none;
font-size: 2em;
line-height: 70px;
transition: 0.2s;
}
div.search a:hover {
color: white;
}
i {
border: solid deepskyblue;
border-width: 0 10px 10px 0;
display: inline-block;
padding: 15px;
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
float: right;
position: relative;
top: 12px;
right: 15px;
}
div.result {
width: 80%;
padding: 20px;
height: 80px;
margin: 10px auto;
background-color: rgba(35, 56, 89, 0.9);
transition: 0.2s;
}
div.result:hover {
background-color: rgba(35, 56, 89, 1);
box-shadow: 0px 0px 28px -4px rgba(0, 0, 0, 0.75);
}
div.result h2 {
color: white;
margin-left: 10px;
line-height: 26px;
text-shadow: 0px 0px 21px rgba(0, 0, 0, 0.2);
}
div.result h3 {
color: lightgray;
font-weight: 100;
margin-left: 10px;
line-height: 26px;
text-decoration: none;
}
div.playerdata {
width: 80%;
margin: 20px auto;
background-color: rgb(35, 56, 89);
padding: 20px;
}
div.playerdata img {
width: 100%;
height: 100%;
background-color: rgba(256, 256, 256, 0.1);
}
div.playerdata h1 {
color: white;
text-shadow: 0px 0px 21px rgba(0, 0, 0, 0.2);
}
div.playerdata div.head {
padding-bottom: 10px;
border-bottom: 5px solid deepskyblue;
margin-bottom: 10px;
text-align: center;
font-size: 3em
}
div.playerdata div.head button {
border-radius: 0px;
border: solid deepskyblue 2px;
padding: 10px;
margin-top: 10px;
}
div.playerdata div.head h2 {
color: deepskyblue;
font-size: 1em;
font-weight: 100;
text-shadow: 0px 0px 21px rgba(0, 0, 0, 0.2);
}
div.playerdata div.head button:hover {
background-color: deepskyblue;
border-color: white;
color: white;
text-shadow: 0px 0px 21px rgba(0, 0, 0, 0.2);
}
div.playerdata div.info {
display: inline-grid;
grid-template-columns: 1fr 1fr;
color: white;
width: 100%;
margin-right: auto;
margin-left: auto;
border-bottom: 5px solid deepskyblue;
padding-bottom: 10px;
}
span.result {
color: lightgray !important;
}
div.playerdata div.info div.right {
border-left: 5px solid deepskyblue;
padding-left: 10px;
min-height: 350px;
}
div.playerdata div.info p {
background-color: deepskyblue;
padding: 10px;
width: 200px;
margin-top: 10px;
}
div.net .hidden {
display: none;
}
div.net:hover .hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 300px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 0.5s;
animation: fadeEffect 0.5s;
}
@-webkit-keyframes fadeEffect {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
@keyframes fadeEffect {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
div.vehicle .hidden {
display: none;
}
div.vehicle:hover .hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 400px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 1s;
animation: fadeEffect 1s;
}
.hidden span {
color: white;
}
div.license div.hidden {
display: none;
padding-left: 3px;
}
div.license:hover div.hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 400px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 1s;
animation: fadeEffect 1s;
}
span.true {
background-color: lawngreen;
margin-top: 3px;
margin-right: 3px;
display: inline-block;
padding: 5px;
}
span.false {
background-color: orangered;
margin-top: 3px;
margin-right: 3px;
display: inline-block;
padding: 5px;
}
div.playerdata div.info p:hover {
background-color: rgba(0, 191, 255, 0.8);
cursor: default;
}
div.playerdata div.info div.police p {
background-color: rgb(70, 133, 201);
}
div.playerdata div.info div.police:hover p {
background-color: rgba(70, 133, 201, 0.9);
}
div.playerdata div.info div.police p.hidden {
display: none;
}
div.playerdata div.info div.police:hover p.hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 300px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 1s;
animation: fadeEffect 1s;
}
div.playerdata div.info div.nhs p {
background-color: rgb(94, 206, 74);
}
div.playerdata div.info div.nhs:hover p {
background-color: rgba(94, 206, 74, 0.9);
}
div.playerdata div.info div.nhs p.hidden {
display: none;
}
div.playerdata div.info div.nhs:hover p.hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 300px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 1s;
animation: fadeEffect 1s;
}
div.playerdata div.info div.unmc p {
background-color: rgb(201, 70, 70);
}
div.playerdata div.info div.unmc:hover p {
background-color: rgba(201, 70, 70, 0.9);
}
div.playerdata div.info div.unmc p.hidden {
display: none;
}
div.playerdata div.info div.unmc:hover p.hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 300px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 1s;
animation: fadeEffect 1s;
}
div.playerdata div.info div.gang p {
background-color: rgb(133, 70, 201);
}
div.playerdata div.info div.gang:hover p {
background-color: rgba(133, 70, 201, 0.9);
}
div.playerdata div.info div.gang p.hidden {
display: none;
}
div.playerdata div.info div.gang:hover p.hidden {
display: block;
background-color: rgb(35, 56, 89);
color: lightgray;
width: 300px;
margin-top: 0px;
border: 2px solid deepskyblue;
-webkit-animation: fadeEffect 1s;
animation: fadeEffect 1s;
}
&#13;
<!DOCTYPE html>
<html>
<head>
<title>Stats page</title>
<link href="css/style.css" type="text/css" rel="stylesheet">
<link href="https://fonts.googleapis.com/css?family=Ubuntu:400,500" rel="stylesheet">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
<script src="assets/js/urlParse.js"></script>
<script type="text/javascript">
var request = "https://api.roleplay.co.uk/v1/player/" + "76561198062083666";
var leaderBoardsRequest = "https://api.roleplay.co.uk/v1/statistics/leaderboards";
var leaderboardsData = "";
var data = "";
function numberWithCommas(x) {
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
}
function error(data) {
console.log(url);
var playerIdExpression = new RegExp("765611[0-9]{11}$");
var guidExpression = new RegExp("[a-f0-9]{32}$");
var request = "https://api.roleplay.co.uk/v1/player/" + "76561198062083666";
try {
if (typeof urlParams['q'][0] !== 'undefined') {
if (playerIdExpression.test(urlParams['q'][0]) == false && guidExpression.test(urlParams['q'][0]) == false) {
window.location.replace("https://stats.roleplay.co.uk/400.html");
} else {
window.location.replace("https://stats.roleplay.co.uk/error.html?errorCode=500&errorQ=" + window.location.href.substring(0, window.location.href.indexOf("?q=")) + "&q=" + urlParams['q'][0] + "?apiQ=" + request);
}
} else {
window.location.replace("https://stats.roleplay.co.uk/400.html");
}
} catch (err) {
window.location.replace("https://stats.roleplay.co.uk/404.html");
}
}
function success(data) {
console.log(data);
var isPolice = false;
var isUNMC = false;
var isNHS = false;
var isGroup = false;
var playerName = data['name'];
var playerID = data['steamid'];
var steamName = data.steam['name'];
var playerWorth = "£" + numberWithCommas(data['bank'] + data['cash']);
var bank = "£" + numberWithCommas(data['bank']);
var cash = "£" + numberWithCommas(data['cash']);
var playerGroups = [];
var wanted = data['wanted'];
var vehicleCount = data['vehicles']['length'];
var playerAdmin = "Not Staff";
var prank = "Not Police";
var nhsrank = "Not NHS";
var urank = "Not UNMC";
var undercover = data['undercoverrank'];
var licencesall = data.civ_licenses;
var licencesfinal = [];
document.title = playerName + " - Roleplay UK - Stats";
for (l = 0; l < data.civ_licenses['length']; l++) {
if (data.civ_licenses[l].owned == true) {
licencesfinal.push(data.civ_licenses[l]);
}
}
switch (wanted) {
case true:
wanted = "Player Wanted!";
break;
case false:
wanted = "Player Not Wanted!";
break;
}
var guid = data['guid'];
if (data['policerank'] > 0) {
playerGroups.push("Altis Police");
var units = [];
switch (data['arrank']) {
case 0:
break;
case 1:
units.push("Armed Response");
break;
}
switch (data['ncarank']) {
case 0:
break;
case 1:
units.push("National Crime Agency");
break;
}
switch (data['npasrank']) {
case 0:
break;
case 1:
units.push("NPAS Tier 1");
break;
case 2:
units.push("NPAS Tier 2");
break;
case 3:
units.push("NPAS Tier 3");
break;
}
switch (data['mporank']) {
case 0:
break;
case 1:
units.push("MPO Tier 1");
break;
case 2:
units.push("MPO Tier 2");
break;
}
switch (undercover) {
case "1":
units.push("Undercover Permit");
break;
}
if (units.length == 0) {
units = "None";
}
for (f = 0; f < units.length; f++) {
if (units.length == 5) {
units = "All";
} else if (f != units.length && f != 0) {
units[f] = " " + units[f];
}
console.log(units);
}
switch (data['policerank']) {
case 1:
var prank = "Police Community Support Officer";
break;
case 2:
var prank = "Probationary Police Constable";
break;
case 3:
var prank = "Police Constable";
break;
case 4:
var prank = "Sergeant";
break;
case 5:
var prank = "Inspector";
break;
case 6:
var prank = "Chief Inspector";
break;
case 7:
var prank = "Superintendent";
break;
case 8:
var prank = "Chief Superintendent";
break;
case 9:
var prank = "Assistant Chief Constable";
break;
case 10:
var prank = "Deputy Chief Constable";
break;
case 11:
var prank = "Chief Constable";
break;
}
isPolice = true;
}
if (data['unmcrank'] > 0) {
playerGroups.push("UNMC");
switch (data['unmcrank']) {
case 1:
var urank = "Recruit";
break;
case 2:
var urank = "Private";
break;
case 3:
var urank = "Private First Class";
break;
case 4:
var urank = "Lance Corporal";
break;
case 5:
var urank = "Corporal";
break;
case 6:
var urank = "Sergeant";
break;
case 7:
var urank = "Staff Sergeant";
break;
case 8:
var urank = "Sergeant Major";
break;
case 9:
var urank = "Lieutenant";
break;
case 10:
var urank = "Captain";
break;
case 11:
var urank = "Major";
break;
case 12:
var urank = "Colonel";
break;
case 13:
var urank = "General";
break;
}
isUNMC = true;
}
if (data['nhsrank'] > 0) {
playerGroups.push("NHS");
var nhsunits = [];
switch (data['nhsarrank']) {
case 0:
break;
case 1:
nhsunits.push("Air Rescue Tier 1");
break;
case 2:
nhsunits.push("Air Rescue Tier 2");
break;
case 3:
nhsunits.push("Air Rescue Tier 3");
break;
}
switch (data['nhsrirrank']) {
case 0:
break;
case 1:
nhsunits.push("Road Incident Responder");
break;
}
if (nhsunits.length == 0) {
units = "None";
}
for (g = 0; g < nhsunits.length; g++) {
if (g != nhsunits.length && g != 0) {
nhsunits[g] = " " + nhsunits[g];
}
}
switch (data['nhsrank']) {
case 1:
var nhsrank = "Student";
break;
case 2:
var nhsrank = "First Aider";
break;
case 3:
var nhsrank = "Paramedic";
break;
case 4:
var nhsrank = "Surgeon";
break;
case 5:
var nhsrank = "Doctor";
break;
case 6:
var nhsrank = "Consultant";
break;
case 7:
var nhsrank = "NHS Administration";
break;
case 8:
var nhsrank = "Chief Medical Officer";
break;
}
isNHS = true;
}
if (data['grouprank'] > 0) {
playerGroups.push(data['groupname']);
isGroup = true;
}
if (data['adminlevel'] > 0 && data['adminlevel'] <= 4) {
playerAdmin = "Staff Team - Level " + data['adminlevel'];
} else if (data['adminlevel'] == 5) {
playerAdmin = "Staff Team - Lead " + data['adminlevel'];
} else if (data['adminlevel'] == 6) {
playerAdmin = "Management";
} else if (data['adminlevel'] == 7) {
playerAdmin = "Developer";
}
//Putting the commas in the right places and formatting it nicely
if (playerGroups.length == 0) {
playerGroups = "None";
}
for (i = 0; i <= playerGroups.length; i++) {
if (i != playerGroups.length && i != 0) {
playerGroups[i] = " " + playerGroups[i]
}
}
if (data['groupname'] == null) {
data['groupname'] = "<b>Not in a group</b>";
}
document.getElementById("playerAdmin").innerHTML = playerAdmin;
document.getElementById("playerID").innerHTML = playerID;
document.getElementById("playerWanted").innerHTML = wanted;
document.getElementById("playerBankMoney").innerHTML = bank;
document.getElementById("playerCashMoney").innerHTML = cash;
document.getElementById("playerTotalMoney").innerHTML = playerWorth;
document.getElementById("playerName").innerHTML = playerName;
document.getElementById("playerTotalMoney").innerHTML = playerWorth;
document.getElementById("playerVehicleCount").innerHTML = vehicleCount;
if (prank != "Not Police") {
document.getElementById("playerPoliceRank").innerHTML = prank + "<br/>";
document.getElementById("playerSpecUnits").innerHTML = "Specialist Units: <b>" + units + "</b>";
} else {
document.getElementById("playerPoliceRank").innerHTML = prank + "";
document.getElementById("playerSpecUnits").style.display = "none";
}
if (nhsrank != "Not NHS") {
document.getElementById("playerNHSRank").innerHTML = nhsrank + "<br/>";
document.getElementById("playerNHSSpecUnits").innerHTML = "Branches: <b>" + nhsunits + "</b>";
} else {
document.getElementById("playerNHSRank").innerHTML = nhsrank + "";
document.getElementById("playerNHSSpecUnits").style.display = "none";
}
document.getElementById("groupLabel").innerHTML = data['groupname'];
if (data['groupname'] != "<b>Not in a group</b>") {
document.getElementById("groupLabel").innerHTML = data['groupname'];
document.getElementById("playerGroupRank").innerHTML = data['grouprank'];
}
document.getElementById("playerGUID").innerHTML = guid;
document.getElementById("playerUNMCRank").innerHTML = urank;
document.getElementById("groupLabel").innerHTML = data['groupname'];
if (playerName.length > 13) {
playerNameDisplay = playerName.substring(0, 10) + "...";
} else {
playerNameDisplay = playerName;
}
if (data['forumid'] != null) {
document.getElementById("buttons").innerHTML += " <a href='" + data['forumurl'] + "' class='button'>Forum Profile</a>";
}
if (data.steam['profileurl'] != null) {
document.getElementById("buttons").innerHTML += " <a href='" + data.steam['profileurl'] + "' class='button'>Steam Profile</a>";
}
document.getElementById("buttons").innerHTML += " <span><a href='https://www.roleplay.co.uk/forms/4-report-a-player/?form_field_26=" + escape(playerName) + "' class='button'>Report</a></span>";
document.getElementById("buttons").innerHTML += " <span><a href='https://www.roleplay.co.uk/forum/123-recommend-a-player/?do=add&topic_title=" + escape(playerName) + "&topic_tags=" + playerID + "' class='button'>Recommend</a></span>";
$.ajax({
dataType: 'json',
url: leaderBoardsRequest,
data: leaderboardsData
});
}
$.ajax({
dataType: 'json',
url: request,
data: data,
success: success,
error: error
});
</script>
</head>
<body>
<div class=playerdata>
<div class=head>
<h1 id="playerName">...</h1>
<h2 id="playerID">...</h2>
<button>Steam Profile</button>
<button>Forum Profile</button>
<button>Report</button>
<button>Recommend</button>
</div>
<div class=info>
<div class=general>
<h2>General Information</h2>
<div class=net>
<p id=playerTotalMoney>...</p>
<p class=hidden><span>Bank: </span><span class=result id=playerBankMoney>...</span><br><span>Cash On Hand: </span><span class=result id=playerCashMoney>...</span></p>
</div>
<div class=vehicle>
<p id=playerVehicleCount>...</p>
<p class=hidden>'VEHICLE LIST'</p>
</div>
<div class=license>
<p>'LICENSES'</p>
<div class=hidden><span class=true>Cement</span><span class=true>Copper</span><span class=false>Iron</span></div>
</div>
<div class=wanted>
<p id=playerWanted>...</p>
</div>
<div class=admin>
<p id=playerAdmin>...</p>
</div>
</div>
<div class="right">
<h2>Organisations</h2>
<div class=police>
<p id=playerPoliceRank>...</p>
<p class=hidden><span>Last Logon: </span><span class=result id=policelog>...</span><br><span id=npas class=false>...</span><span id=mpo class=false>...</span><span id=ar class=false>...</span><span id=nca class=false>...</span><span id=rtu class=false>...</span>
<span
id=undercover class=false>...</span>
</p>
</div>
<div class=nhs>
<p id=playerNHSRank>...</p>
<p class=hidden><span>Last Logon: </span><span class=result id=nhslog>...</span><br><span class=true>Undercover</span><span class=false>NCA</span><span class=true>AR</span><span class=true>MPO</span><span class=false>NPAS</span></p>
</div>
<div class=unmc>
<p>'UNMC RANK'</p>
<p class=hidden><span>Last Logon: </span><span class=result id=unmclog>...</span><br><span class=true>Undercover</span><span class=false>NCA</span><span class=true>AR</span><span class=true>MPO</span><span class=false>NPAS</span></p>
</div>
<div class=gang>
<p id=groupLabel>...</p>
<p class=hidden><span>Last Logon:</span> 10/09/08 12:11:10<br><span class=true>Undercover</span><span class=false>NCA</span><span class=true>AR</span><span class=true>MPO</span><span class=false>NPAS</span></p>
</div>
</div>
</div>
</div>
</body>
</html>
&#13;
答案 0 :(得分:0)
显然这是在加载DOM之前运行的:
$.ajax({
dataType: 'json',
url: request,
data: data,
success: success,
error: error
});
这可能是你得到的错误是随机的原因。
也许你应该尝试类似的东西:
function ajaxLoad(){
$.ajax({
dataType: 'json',
url: request,
data: data,
success: success,
error: error
});
}
window.onload = ajaxLoad;
最佳做法是在文档末尾放置/加载任何javascript(代码或文件)。