Array vs object
How do I make an array vs object?
Forked from brendan-mullins's Pen array vs object.. What is a array vs object? How do you make a array vs object? This script and codes were developed by Andres on 26 August 2022, Friday.
Array vs object - Script Codes HTML Codes
<!DOCTYPE html>
<html >
<head> <meta charset="UTF-8"> <title>array vs object</title> <link rel="stylesheet" href="css/style.css">
</head>
<body> <script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
<script src='http://brendan-mullins.com/faker.js'></script> <script src="js/index.js"></script>
</body>
</html>
Array vs object - Script Codes CSS Codes
div { border: 1px solid #000; padding: 10px; margin: 10px;
}
input { margin: 10px 10px 0; padding: 6px;
}
h1,h2 { margin: 50px 0 0 10px;
}
span { display: block; padding: 3px 0;
}
span.arr { color: orange;
}
span.obj { color: rgb(159, 255, 229);
}
.log { color: #00C328; background: #333; font-family: monospace;
}
.op { height: 100px; overflow: auto; text-transform: capitalize;
}
i { font-style: normal; color: #fff;
}
Array vs object - Script Codes JS Codes
var dataLength = 10000;
var averageArray = [], averageObj = [];
var options = [ 'Array', 'Object'
];
var optionsStr = '';
for(i=0;i<options.length;i++){ optionsStr += '<option value="'+i+'">'+options[i]+'</option>';
}
$('body').append('<h1>Search for a name</h1>');
var $search = $('<input type="text" value="Name search" />').appendTo('body');
var $select = $('<select>'+optionsStr+'</select>').appendTo('body');
$('body').append('<h2>List:</h2>');
var $op = $('<div class="op"></div>').appendTo('body');
$('body').append('<h2>Log:</h2>');
$avgArr = $('<div>Average time for array: <b>0ms</b></div>').appendTo('body');
$avgObj = $('<div>Average time for object: <b>0ms</b></div>').appendTo('body');
var $log = $('<div class="log"></div>').appendTo('body');
var start, stop, diff=-1, results;
function log(what, cls, avg) { if (typeof avg != undefined){ if (avg == 0) { averageArray.push(diff); var total = 0; for (var i = 0; i < averageArray.length; i++) { total += averageArray[i]; } if(total){ $avgArr.find('b').html((total/averageArray.length) + 'ms'); } }else if (avg == 1) { averageObj.push(diff); var total = 0; for (var i = 0; i < averageObj.length; i++) { total += averageObj[i]; } if(total){ $avgObj.find('b').html((total/averageObj.length) + 'ms'); } } } $log.prepend('<span class="'+cls+'"><i>'+ diff +'ms </i> '+what+'</span>');
}
// generate dummmy data
var arr = [];
var obj = {};
start = +new Date();
for (var i = 0; i < dataLength; i++) { var fN = faker.name.firstName().toLowerCase(), lN = faker.name.lastName().toLowerCase(), email = faker.internet.email(), id = faker.random.uuid(); arr.push( { 'firstName': fN, 'lastName': lN, 'email': email, 'id': id } ) var objlit = fN.toLowerCase()+lN.toLowerCase(); obj[objlit] = { 'firstName': fN, 'lastName': lN, 'email': email, 'id': id }
};
stop = +new Date();
diff = stop-start;
log('generated '+dataLength+' elements');
function checkArray(search, fn) { start = 'null', stop = 'null', diff = 'null', results = []; start = +new Date(); for (var i = 0; i < arr.length; i++) { var name = arr[i].firstName+arr[i].lastName; if (name.indexOf(search) != -1) { //if (name == search) { results.push(arr[i]); } } var addHTML = ''; for (var i = 0; i < results.length; i++) { addHTML += '<span>'+(results[i].firstName+' '+results[i].lastName)+'</span>'; } $op.html(addHTML); stop = +new Date(); diff = stop-start; log('Array: <b>'+ results.length +'</b> results for: '+search, 'arr', $select.val());
}
function checkObject(search) { start = 'null', stop = 'null', diff = 'null', results = []; start = +new Date(); //for (var i = 0; i < arr.length; i++) { // var name = arr[i].firstName+arr[i].lastName; // if (name.indexOf(search) != -1) { // //if (name == search) { // results.push(arr[i]); // } //} for (var key in obj) { if (key.indexOf(search) != -1) { results.push(obj[key]); } } var addHTML = ''; for (var i = 0; i < results.length; i++) { addHTML += '<span>'+(results[i].firstName+' '+results[i].lastName)+'</span>'; } $op.html(addHTML); stop = +new Date(); diff = stop-start; log('Object: <b>'+ results.length +'</b> results for: '+search, 'obj', $select.val());
}
$search.on('keyup', function(){ var $this = $(this); var search = $this.val().toLowerCase().replace(/ /g, ''); var option = $select.val(); //console.log(data); if (search.length) { if (option == 0) { checkArray(search); }else if (option == 1) { checkObject(search); } }else{ $op.html(''); }
}).on('focus', function(){ $(this).select();
});
//console.log(array, obj);
Developer | Andres |
Username | Angelfire |
Uploaded | August 26, 2022 |
Rating | 3 |
Size | 3,043 Kb |
Views | 48,576 |
Find the perfect freelance services for your business! Fiverr's mission is to change how the world works together. Fiverr connects businesses with freelancers offering digital services in 500+ categories. Find Developer!
Name | Size |
Font Awesome Flat Icons | 5,750 Kb |
A Pen by Andres | 2,205 Kb |
Latest Posts Widget | 3,059 Kb |
Simple Dashboard Search | 4,595 Kb |
JQuery Payment | 4,158 Kb |
Social Media Button | 3,566 Kb |
Clean Animated Input Labels | 4,409 Kb |
Flexbox Admin Template | 4,741 Kb |
Chart.js Infobox | 3,900 Kb |
CSS3 animated Pricing tables | 3,550 Kb |
Jasper is the AI Content Generator that helps you and your team break through creative blocks to create amazing, original content 10X faster. Discover all the ways the Jasper AI Content Platform can help streamline your creative workflows. Start For Free!
Name | Username | Size |
AOR site logo | Thatbram | 2,527 Kb |
SVG Animation | Pollardld | 3,133 Kb |
Pure CSS Dial | Lukewatts | 3,018 Kb |
Svg animation draw | SzymonDziewonski | 5,545 Kb |
Cloud upload | Jaflo | 2,774 Kb |
Barber Shop | Bhlaird | 6,270 Kb |
Minimelephant | Smashlee | 2,507 Kb |
Weather App | OmranAbazid | 2,596 Kb |
The Walking Raymarcher | Xorxor_hu | 7,934 Kb |
Subtle site navigation with description | Necks | 3,206 Kb |
Surf anonymously, prevent hackers from acquiring your IP address, send anonymous email, and encrypt your Internet connection. High speed, ultra secure, and easy to use. Instant setup. Hide Your IP Now!