Допустим у нас есть multiple select box с большим количеством options, ну скажем 450. Надо выделить все.
Рассмотрим 2 способа.
Решение 1. В лоб
selectAll_method1 = function(selectBoxId, selected) {
var selectBox = document.getElementById(selectBoxId);
for (var i=0; i < selectBox.options.length; i++) {
selectBox.options[i].selected = selected;
}
} 85 LastName = 85 86 LastName = 86 95 LastName = 95 101 LastName = 101 102 LastName = 102 103 LastName = 103 113 LastName = 113 117 LastName = 117 118 LastName = 118 119 LastName = 119 136 LastName = 136 141 LastName = 141 144 LastName = 144 145 LastName = 145 150 LastName = 150 152 LastName = 152 157 LastName = 157 161 LastName = 161 170 LastName = 170 173 LastName = 173 174 LastName = 174 176 LastName = 176 189 LastName = 189 193 LastName = 193 194 LastName = 194 196 LastName = 196 202 LastName = 202 205 LastName = 205 206 LastName = 206 207 LastName = 207 208 LastName = 208 210 LastName = 210 216 LastName = 216 219 LastName = 219 221 LastName = 221 223 LastName = 223 224 LastName = 224 225 LastName = 225 226 LastName = 226 230 LastName = 230 232 LastName = 232 234 LastName = 234 235 LastName = 235 237 LastName = 237 241 LastName = 241 244 LastName = 244 251 LastName = 251 252 LastName = 252 256 LastName = 256 257 LastName = 257 260 LastName = 260 262 LastName = 262 265 LastName = 265 275 LastName = 275 277 LastName = 277 280 LastName = 280 281 LastName = 281 282 LastName = 282 284 LastName = 284 290 LastName = 290 291 LastName = 291 292 LastName = 292 294 LastName = 294 296 LastName = 296 297 LastName = 297 298 LastName = 298 302 LastName = 302 303 LastName = 303 304 LastName = 304 312 LastName = 312 313 LastName = 313 314 LastName = 314 316 LastName = 316 319 LastName = 319 320 LastName = 320 324 LastName = 324 326 LastName = 326 328 LastName = 328 329 LastName = 329 330 LastName = 330 331 LastName = 331 332 LastName = 332 333 LastName = 333 334 LastName = 334 335 LastName = 335 337 LastName = 337 338 LastName = 338 339 LastName = 339 345 LastName = 345 346 LastName = 346 347 LastName = 347 348 LastName = 348 349 LastName = 349 350 LastName = 350 351 LastName = 351 353 LastName = 353 354 LastName = 354 355 LastName = 355 357 LastName = 357 358 LastName = 358 359 LastName = 359 361 LastName = 361 368 LastName = 368 371 LastName = 371 372 LastName = 372 373 LastName = 373 375 LastName = 375 377 LastName = 377 381 LastName = 381 382 LastName = 382 385 LastName = 385 386 LastName = 386 388 LastName = 388 389 LastName = 389 391 LastName = 391 392 LastName = 392 396 LastName = 396 397 LastName = 397 401 LastName = 401 404 LastName = 404 405 LastName = 405 406 LastName = 406 414 LastName = 414 418 LastName = 418 419 LastName = 419 422 LastName = 422 425 LastName = 425 426 LastName = 426 427 LastName = 427 428 LastName = 428 430 LastName = 430 432 LastName = 432 438 LastName = 438 439 LastName = 439 440 LastName = 440 441 LastName = 441 442 LastName = 442 444 LastName = 444 446 LastName = 446 448 LastName = 448 453 LastName = 453 455 LastName = 455 457 LastName = 457 463 LastName = 463 464 LastName = 464 472 LastName = 472 473 LastName = 473 476 LastName = 476 477 LastName = 477 478 LastName = 478 480 LastName = 480 481 LastName = 481 482 LastName = 482 483 LastName = 483 484 LastName = 484 485 LastName = 485 486 LastName = 486 487 LastName = 487 488 LastName = 488 491 LastName = 491 493 LastName = 493 496 LastName = 496 498 LastName = 498 501 LastName = 501 502 LastName = 502 505 LastName = 505 506 LastName = 506 507 LastName = 507 508 LastName = 508 509 LastName = 509 510 LastName = 510 511 LastName = 511 512 LastName = 512 513 LastName = 513 514 LastName = 514 516 LastName = 516 518 LastName = 518 519 LastName = 519 520 LastName = 520 521 LastName = 521 522 LastName = 522 524 LastName = 524 525 LastName = 525 526 LastName = 526 527 LastName = 527 528 LastName = 528 530 LastName = 530 533 LastName = 533 534 LastName = 534 535 LastName = 535 537 LastName = 537 538 LastName = 538 544 LastName = 544 545 LastName = 545 546 LastName = 546 547 LastName = 547 548 LastName = 548 549 LastName = 549 550 LastName = 550 551 LastName = 551 552 LastName = 552 553 LastName = 553 554 LastName = 554 557 LastName = 557 559 LastName = 559 562 LastName = 562 563 LastName = 563 564 LastName = 564 565 LastName = 565 566 LastName = 566 609 LastName = 609 928 LastName = 928 930 LastName = 930 932 LastName = 932 935 LastName = 935 936 LastName = 936 938 LastName = 938 950 LastName = 950 951 LastName = 951 958 LastName = 958 959 LastName = 959 962 LastName = 962 981 LastName = 981 982 LastName = 982 990 LastName = 990 85 LastName = 85 86 LastName = 86 95 LastName = 95 101 LastName = 101 102 LastName = 102 103 LastName = 103 113 LastName = 113 117 LastName = 117 118 LastName = 118 119 LastName = 119 136 LastName = 136 141 LastName = 141 144 LastName = 144 145 LastName = 145 150 LastName = 150 152 LastName = 152 157 LastName = 157 161 LastName = 161 170 LastName = 170 173 LastName = 173 174 LastName = 174 176 LastName = 176 189 LastName = 189 193 LastName = 193 194 LastName = 194 196 LastName = 196 202 LastName = 202 205 LastName = 205 206 LastName = 206 207 LastName = 207 208 LastName = 208 210 LastName = 210 216 LastName = 216 219 LastName = 219 221 LastName = 221 223 LastName = 223 224 LastName = 224 225 LastName = 225 226 LastName = 226 230 LastName = 230 232 LastName = 232 234 LastName = 234 235 LastName = 235 237 LastName = 237 241 LastName = 241 244 LastName = 244 251 LastName = 251 252 LastName = 252 256 LastName = 256 257 LastName = 257 260 LastName = 260 262 LastName = 262 265 LastName = 265 275 LastName = 275 277 LastName = 277 280 LastName = 280 281 LastName = 281 282 LastName = 282 284 LastName = 284 290 LastName = 290 291 LastName = 291 292 LastName = 292 294 LastName = 294 296 LastName = 296 297 LastName = 297 298 LastName = 298 302 LastName = 302 303 LastName = 303 304 LastName = 304 312 LastName = 312 313 LastName = 313 314 LastName = 314 316 LastName = 316 319 LastName = 319 320 LastName = 320 324 LastName = 324 326 LastName = 326 328 LastName = 328 329 LastName = 329 330 LastName = 330 331 LastName = 331 332 LastName = 332 333 LastName = 333 334 LastName = 334 335 LastName = 335 337 LastName = 337 338 LastName = 338 339 LastName = 339 345 LastName = 345 346 LastName = 346 347 LastName = 347 348 LastName = 348 349 LastName = 349 350 LastName = 350 351 LastName = 351 353 LastName = 353 354 LastName = 354 355 LastName = 355 357 LastName = 357 358 LastName = 358 359 LastName = 359 361 LastName = 361 368 LastName = 368 371 LastName = 371 372 LastName = 372 373 LastName = 373 375 LastName = 375 377 LastName = 377 381 LastName = 381 382 LastName = 382 385 LastName = 385 386 LastName = 386 388 LastName = 388 389 LastName = 389 391 LastName = 391 392 LastName = 392 396 LastName = 396 397 LastName = 397 401 LastName = 401 404 LastName = 404 405 LastName = 405 406 LastName = 406 414 LastName = 414 418 LastName = 418 419 LastName = 419 422 LastName = 422 425 LastName = 425 426 LastName = 426 427 LastName = 427 428 LastName = 428 430 LastName = 430 432 LastName = 432 438 LastName = 438 439 LastName = 439 440 LastName = 440 441 LastName = 441 442 LastName = 442 444 LastName = 444 446 LastName = 446 448 LastName = 448 453 LastName = 453 455 LastName = 455 457 LastName = 457 463 LastName = 463 464 LastName = 464 472 LastName = 472 473 LastName = 473 476 LastName = 476 477 LastName = 477 478 LastName = 478 480 LastName = 480 481 LastName = 481 482 LastName = 482 483 LastName = 483 484 LastName = 484 485 LastName = 485 486 LastName = 486 487 LastName = 487 488 LastName = 488 491 LastName = 491 493 LastName = 493 496 LastName = 496 498 LastName = 498 501 LastName = 501 502 LastName = 502 505 LastName = 505 506 LastName = 506 507 LastName = 507 508 LastName = 508 509 LastName = 509 510 LastName = 510 511 LastName = 511 512 LastName = 512 513 LastName = 513 514 LastName = 514 516 LastName = 516 518 LastName = 518 519 LastName = 519 520 LastName = 520 521 LastName = 521 522 LastName = 522 524 LastName = 524 525 LastName = 525 526 LastName = 526 527 LastName = 527 528 LastName = 528 530 LastName = 530 533 LastName = 533 534 LastName = 534 535 LastName = 535 537 LastName = 537 538 LastName = 538 544 LastName = 544 545 LastName = 545 546 LastName = 546 547 LastName = 547 548 LastName = 548 549 LastName = 549 550 LastName = 550 551 LastName = 551 552 LastName = 552 553 LastName = 553 554 LastName = 554 557 LastName = 557 559 LastName = 559 562 LastName = 562 563 LastName = 563 564 LastName = 564 565 LastName = 565 566 LastName = 566 609 LastName = 609 928 LastName = 928 930 LastName = 930 932 LastName = 932 935 LastName = 935 936 LastName = 936 938 LastName = 938 950 LastName = 950 951 LastName = 951 958 LastName = 958 959 LastName = 959 962 LastName = 962 981 LastName = 981 982 LastName = 982 990 LastName = 990
В IE 8 это происходит очень долго. Мы визуально видим как браузер пробегается по опциям при этом проматывая скролл.
Решение 2. Пересоздание опций.
selectAll_method2 = function(selectBoxId, selected) {
var selectBox = document.getElementById(selectBoxId);
var optionsCopy = new Array();
for (var i=0; i < selectBox.options.length; i++) {
var option = selectBox.options[i];
optionsCopy[i] = new Option(option.text,option.value,selected,selected);
}
selectBox.options.length = 0;
for (var i=0; i < optionsCopy.length; i++) {
selectBox.options[i] = optionsCopy[i];
}
} 85 LastName = 85 86 LastName = 86 95 LastName = 95 101 LastName = 101 102 LastName = 102 103 LastName = 103 113 LastName = 113 117 LastName = 117 118 LastName = 118 119 LastName = 119 136 LastName = 136 141 LastName = 141 144 LastName = 144 145 LastName = 145 150 LastName = 150 152 LastName = 152 157 LastName = 157 161 LastName = 161 170 LastName = 170 173 LastName = 173 174 LastName = 174 176 LastName = 176 189 LastName = 189 193 LastName = 193 194 LastName = 194 196 LastName = 196 202 LastName = 202 205 LastName = 205 206 LastName = 206 207 LastName = 207 208 LastName = 208 210 LastName = 210 216 LastName = 216 219 LastName = 219 221 LastName = 221 223 LastName = 223 224 LastName = 224 225 LastName = 225 226 LastName = 226 230 LastName = 230 232 LastName = 232 234 LastName = 234 235 LastName = 235 237 LastName = 237 241 LastName = 241 244 LastName = 244 251 LastName = 251 252 LastName = 252 256 LastName = 256 257 LastName = 257 260 LastName = 260 262 LastName = 262 265 LastName = 265 275 LastName = 275 277 LastName = 277 280 LastName = 280 281 LastName = 281 282 LastName = 282 284 LastName = 284 290 LastName = 290 291 LastName = 291 292 LastName = 292 294 LastName = 294 296 LastName = 296 297 LastName = 297 298 LastName = 298 302 LastName = 302 303 LastName = 303 304 LastName = 304 312 LastName = 312 313 LastName = 313 314 LastName = 314 316 LastName = 316 319 LastName = 319 320 LastName = 320 324 LastName = 324 326 LastName = 326 328 LastName = 328 329 LastName = 329 330 LastName = 330 331 LastName = 331 332 LastName = 332 333 LastName = 333 334 LastName = 334 335 LastName = 335 337 LastName = 337 338 LastName = 338 339 LastName = 339 345 LastName = 345 346 LastName = 346 347 LastName = 347 348 LastName = 348 349 LastName = 349 350 LastName = 350 351 LastName = 351 353 LastName = 353 354 LastName = 354 355 LastName = 355 357 LastName = 357 358 LastName = 358 359 LastName = 359 361 LastName = 361 368 LastName = 368 371 LastName = 371 372 LastName = 372 373 LastName = 373 375 LastName = 375 377 LastName = 377 381 LastName = 381 382 LastName = 382 385 LastName = 385 386 LastName = 386 388 LastName = 388 389 LastName = 389 391 LastName = 391 392 LastName = 392 396 LastName = 396 397 LastName = 397 401 LastName = 401 404 LastName = 404 405 LastName = 405 406 LastName = 406 414 LastName = 414 418 LastName = 418 419 LastName = 419 422 LastName = 422 425 LastName = 425 426 LastName = 426 427 LastName = 427 428 LastName = 428 430 LastName = 430 432 LastName = 432 438 LastName = 438 439 LastName = 439 440 LastName = 440 441 LastName = 441 442 LastName = 442 444 LastName = 444 446 LastName = 446 448 LastName = 448 453 LastName = 453 455 LastName = 455 457 LastName = 457 463 LastName = 463 464 LastName = 464 472 LastName = 472 473 LastName = 473 476 LastName = 476 477 LastName = 477 478 LastName = 478 480 LastName = 480 481 LastName = 481 482 LastName = 482 483 LastName = 483 484 LastName = 484 485 LastName = 485 486 LastName = 486 487 LastName = 487 488 LastName = 488 491 LastName = 491 493 LastName = 493 496 LastName = 496 498 LastName = 498 501 LastName = 501 502 LastName = 502 505 LastName = 505 506 LastName = 506 507 LastName = 507 508 LastName = 508 509 LastName = 509 510 LastName = 510 511 LastName = 511 512 LastName = 512 513 LastName = 513 514 LastName = 514 516 LastName = 516 518 LastName = 518 519 LastName = 519 520 LastName = 520 521 LastName = 521 522 LastName = 522 524 LastName = 524 525 LastName = 525 526 LastName = 526 527 LastName = 527 528 LastName = 528 530 LastName = 530 533 LastName = 533 534 LastName = 534 535 LastName = 535 537 LastName = 537 538 LastName = 538 544 LastName = 544 545 LastName = 545 546 LastName = 546 547 LastName = 547 548 LastName = 548 549 LastName = 549 550 LastName = 550 551 LastName = 551 552 LastName = 552 553 LastName = 553 554 LastName = 554 557 LastName = 557 559 LastName = 559 562 LastName = 562 563 LastName = 563 564 LastName = 564 565 LastName = 565 566 LastName = 566 609 LastName = 609 928 LastName = 928 930 LastName = 930 932 LastName = 932 935 LastName = 935 936 LastName = 936 938 LastName = 938 950 LastName = 950 951 LastName = 951 958 LastName = 958 959 LastName = 959 962 LastName = 962 981 LastName = 981 982 LastName = 982 990 LastName = 990 85 LastName = 85 86 LastName = 86 95 LastName = 95 101 LastName = 101 102 LastName = 102 103 LastName = 103 113 LastName = 113 117 LastName = 117 118 LastName = 118 119 LastName = 119 136 LastName = 136 141 LastName = 141 144 LastName = 144 145 LastName = 145 150 LastName = 150 152 LastName = 152 157 LastName = 157 161 LastName = 161 170 LastName = 170 173 LastName = 173 174 LastName = 174 176 LastName = 176 189 LastName = 189 193 LastName = 193 194 LastName = 194 196 LastName = 196 202 LastName = 202 205 LastName = 205 206 LastName = 206 207 LastName = 207 208 LastName = 208 210 LastName = 210 216 LastName = 216 219 LastName = 219 221 LastName = 221 223 LastName = 223 224 LastName = 224 225 LastName = 225 226 LastName = 226 230 LastName = 230 232 LastName = 232 234 LastName = 234 235 LastName = 235 237 LastName = 237 241 LastName = 241 244 LastName = 244 251 LastName = 251 252 LastName = 252 256 LastName = 256 257 LastName = 257 260 LastName = 260 262 LastName = 262 265 LastName = 265 275 LastName = 275 277 LastName = 277 280 LastName = 280 281 LastName = 281 282 LastName = 282 284 LastName = 284 290 LastName = 290 291 LastName = 291 292 LastName = 292 294 LastName = 294 296 LastName = 296 297 LastName = 297 298 LastName = 298 302 LastName = 302 303 LastName = 303 304 LastName = 304 312 LastName = 312 313 LastName = 313 314 LastName = 314 316 LastName = 316 319 LastName = 319 320 LastName = 320 324 LastName = 324 326 LastName = 326 328 LastName = 328 329 LastName = 329 330 LastName = 330 331 LastName = 331 332 LastName = 332 333 LastName = 333 334 LastName = 334 335 LastName = 335 337 LastName = 337 338 LastName = 338 339 LastName = 339 345 LastName = 345 346 LastName = 346 347 LastName = 347 348 LastName = 348 349 LastName = 349 350 LastName = 350 351 LastName = 351 353 LastName = 353 354 LastName = 354 355 LastName = 355 357 LastName = 357 358 LastName = 358 359 LastName = 359 361 LastName = 361 368 LastName = 368 371 LastName = 371 372 LastName = 372 373 LastName = 373 375 LastName = 375 377 LastName = 377 381 LastName = 381 382 LastName = 382 385 LastName = 385 386 LastName = 386 388 LastName = 388 389 LastName = 389 391 LastName = 391 392 LastName = 392 396 LastName = 396 397 LastName = 397 401 LastName = 401 404 LastName = 404 405 LastName = 405 406 LastName = 406 414 LastName = 414 418 LastName = 418 419 LastName = 419 422 LastName = 422 425 LastName = 425 426 LastName = 426 427 LastName = 427 428 LastName = 428 430 LastName = 430 432 LastName = 432 438 LastName = 438 439 LastName = 439 440 LastName = 440 441 LastName = 441 442 LastName = 442 444 LastName = 444 446 LastName = 446 448 LastName = 448 453 LastName = 453 455 LastName = 455 457 LastName = 457 463 LastName = 463 464 LastName = 464 472 LastName = 472 473 LastName = 473 476 LastName = 476 477 LastName = 477 478 LastName = 478 480 LastName = 480 481 LastName = 481 482 LastName = 482 483 LastName = 483 484 LastName = 484 485 LastName = 485 486 LastName = 486 487 LastName = 487 488 LastName = 488 491 LastName = 491 493 LastName = 493 496 LastName = 496 498 LastName = 498 501 LastName = 501 502 LastName = 502 505 LastName = 505 506 LastName = 506 507 LastName = 507 508 LastName = 508 509 LastName = 509 510 LastName = 510 511 LastName = 511 512 LastName = 512 513 LastName = 513 514 LastName = 514 516 LastName = 516 518 LastName = 518 519 LastName = 519 520 LastName = 520 521 LastName = 521 522 LastName = 522 524 LastName = 524 525 LastName = 525 526 LastName = 526 527 LastName = 527 528 LastName = 528 530 LastName = 530 533 LastName = 533 534 LastName = 534 535 LastName = 535 537 LastName = 537 538 LastName = 538 544 LastName = 544 545 LastName = 545 546 LastName = 546 547 LastName = 547 548 LastName = 548 549 LastName = 549 550 LastName = 550 551 LastName = 551 552 LastName = 552 553 LastName = 553 554 LastName = 554 557 LastName = 557 559 LastName = 559 562 LastName = 562 563 LastName = 563 564 LastName = 564 565 LastName = 565 566 LastName = 566 609 LastName = 609 928 LastName = 928 930 LastName = 930 932 LastName = 932 935 LastName = 935 936 LastName = 936 938 LastName = 938 950 LastName = 950 951 LastName = 951 958 LastName = 958 959 LastName = 959 962 LastName = 962 981 LastName = 981 982 LastName = 982 990 LastName = 990
Странно, но пересоздание опций работает значительно быстрее. Сравним?
IE 7 IE 8 FF 3.6 Chrome 4.1
Метод 1 900 1600 1170 7
Метод 2 270 300 460 450
Очевидно что в IE8 есть досадный баг связаный с выделением. Хром приятно порадовал.
Плюсы метода 2.
1. Почти везде быстрее, кроме хрома
2. Визуально приятнее так как селект бокс не прокручивается вниз.
Минусы метода 2.
1. Пересоздание не копируют свойства опций, например, class. При необходимости метод можна расширить, правда не известно как это отобразится на скорости его выполнения.
2. Пересоздание будет происходить всегда. В случае первого метода, если все опции уже выбраны метод исполняется быстро, так как менять состояние опций не приходится.
3. Снятие выделения методом 1 везде быстрее
4. Это хак.
Итого: для выделения юзаем метод 2, для снятия выделения - метод 1.
Комментариев нет:
Отправить комментарий