const filteredHomes = json.homes.filter(x => x.price <= 1000 && x.sqft >= 500 && x.num_of_beds >=2 && x.num_of_baths >= 2.5);
var id = "ctl03_Tabs1";
var lastFive = id.substr(id.length - 5); // => "Tabs1"
var lastChar = id.substr(id.length - 1);
for (const [key, value] of Object.entries(object)) {
console.log(key, value);
}
for (const item of array) {
console.log(item);
}
## dictionary length
```javascript
Object.keys(dictionary).length
("key" in obj)
The slice() method returns the selected elements in an array, as a new array object.
The slice() method selects the elements starting at the given start argument, and ends at, but does not include, the given end argument.
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1, 3); // "Orange", "Lemon"
https://www.w3schools.com/jsref/jsref_slice_array.asp
var resizedCanvas = document.createElement("canvas");
var resizedContext = resizedCanvas.getContext("2d");
resizedCanvas.height = "100";
resizedCanvas.width = "200";
var canvas = document.getElementById("original-canvas");
resizedContext.drawImage(canvas, 0, 0, 200, 100);
var myResizedData = resizedCanvas.toDataURL();
https://stackoverflow.com/a/23481814
var canvas = document.getElementById("c");
var ctx = canvas.getContext("2d");
var image = new Image();
image.onload = function() {
ctx.drawImage(image, 0, 0);
};
image.src = "";
<canvas id="c"></canvas>
https://stackoverflow.com/a/4409745
var canvas = document.getElementById('viewport'),
context = canvas.getContext('2d');
make_base();
function make_base()
{
base_image = new Image();
base_image.src = 'img/base.png';
base_image.onload = function(){
context.drawImage(base_image, 0, 0);
}
}
https://stackoverflow.com/a/6011402
window.onload = function(){
var canvas = document.getElementById("myCanvas");
var context = canvas.getContext("2d");
var imageObj = new Image();
imageObj.onload = function(){
context.drawImage(imageObj, 10, 10);
context.font = "40pt Calibri";
context.fillText("My TEXT!", 20, 20);
};
imageObj.src = "darth-vader.jpg";
};
https://stackoverflow.com/a/8429496
Array.prototype.asyncForEach = async function(callback, thisArg) {
thisArg = thisArg || this
for (let i = 0, l = this.length; i !== l; ++i) {
await callback.call(thisArg, this[i], i, this)
}
}
const greetPeople = async (names) => {
const delay = () => new Promise(resolve => setTimeout(resolve, 3000))
await names.asyncForEach(async (name) => {
await delay()
console.log(`Greetings to you ${name}`)
})
console.log('farewell')
}
greetPeople(['George', 'Margie', 'Anna'])
https://dev.to/dinos_vl/breaking-down-confusion-of-combining-async-await-with-array-foreach-4alb
const search = window.location.search;
const params = new URLSearchParams(search);
const foo = params.get('bar');
jest -t 'fix-order-test'