Кажется, что Powershell получает неверное количество элементов в массиве параметров

Короткие и простые: поскольку элементы, которые вы ищете, не существуют в документе (пока).


В оставшуюся часть этого ответа я буду использовать getElementById как пример, но то же самое относится к getElementsByTagName , querySelector и любому другому методу DOM, который выбирает элементы.

Возможные причины

Есть две причины, по которым элемент может не существовать:

  1. Элемент с переданным идентификатором действительно не существует в документе. Вы должны дважды проверить, что идентификатор, который вы передаете на getElementById, действительно соответствует идентификатору существующего элемента в (сгенерированном) HTML и что у вас не было с ошибкой идентификатор (идентификаторы чувствительный !). Кстати, в большинстве современных браузеров , которые реализуют методы querySelector() и querySelectorAll(), нотация стиля CSS используется для извлечения элемента его id, например: document.querySelector('#elementID'), в отличие от способа, с помощью которого элемент извлекается его id в [[16]; в первом символе # необходимо, во втором это приведет к тому, что элемент не будет извлечен.
  2. Элемент не существует в данный момент , который вы вызываете getElementById ].

Последний случай довольно распространен. Браузеры анализируют и обрабатывают HTML сверху вниз. Это означает, что любой вызов элемента DOM, который встречается до появления этого элемента DOM в HTML, не будет выполнен.

Рассмотрим следующий пример:



Появляется div после script. В настоящий момент сценарий выполняется, элемент не существует , но и getElementById вернут null.

jQuery

То же самое относится к все селекторы с jQuery. jQuery не найдет элементов, если вы ошибочно написали ваш селектор, или вы пытаетесь выбрать их , прежде чем они на самом деле существуют .

Добавленный поворот - это когда jQuery не найден потому, что вы загрузили скрипт без протокола и запускаетесь из файловой системы:


этот синтаксис используется, чтобы позволить сценарию загружаться через HTTPS на странице с протоколом https: // и для загрузки HTTP-версии на странице с протоколом http: //

У этого есть неудачный побочный эффект попытки и невозможность загрузить file://somecdn.somewhere.com...


Решения

Прежде чем позвонить getElementById (или любой метод DOM, если на то пошло), убедитесь, что элементы, к которым вы хотите получить доступ, существуют, т. е. загружается DOM.

Это может быть обеспечено просто добавив ваш JavaScript после к соответствующему элементу DOM

, и в этом случае вы также можете поместить код непосредственно перед тегом закрывающего тела () (все DOM элементы будут доступны в момент выполнения скрипта). [/ g3 6]

Другие решения включают прослушивание событий load [MDN] или DOMContentLoaded [MDN] . В этих случаях не имеет значения, где в документе вы помещаете код JavaScript, вам просто нужно запомнить, чтобы весь обработчик DOM обрабатывался в обработчиках событий.

Пример:

window.onload = function() {
    // process DOM elements here
};

// or

// does not work IE 8 and below
document.addEventListener('DOMContentLoaded', function() {
    // process DOM elements here
});

Более подробную информацию об обработке событий и различиях браузера см. в статьях на странице quirksmode.org .

jQuery

Сначала убедитесь, что jQuery загружен правильно , Используйте инструменты разработчика браузера , чтобы узнать, был ли найден файл jQuery и исправлен ли URL-адрес, если он не был (например, добавьте схему http: или https: в начале, отрегулируйте путь, и т. д.)

Прослушивание событий load / DOMContentLoaded - это именно то, что делает jQuery с .ready() [docs] . Весь ваш код jQuery, который влияет на элемент DOM, должен находиться внутри этого обработчика событий.

На самом деле в учебнике j8uery явно указано:

Как почти все, что мы делаем при использовании jQuery, читает или манипулирует объектной моделью документа (DOM), мы должны убедиться, что мы начинаем добавлять события и т. д., как только DOM готов.

Для этого мы регистрируем готовое событие для документа.

$(document).ready(function() {
   // do stuff when DOM is ready
});
blockquote>

В качестве альтернативы вы также можете использовать сокращенный синтаксис:

$(function() {
    // do stuff when DOM is ready
});

Оба эквивалентны.

1
задан Carbon 17 January 2019 в 17:00
поделиться

2 ответа

«- one» передается как целая строка, поскольку преобразование происходит перед вызовом метода.

Вы можете альтернативно назвать это следующим образом

powershell -Command {.\test.ps1 -one "hello","cat","Dog"}
0
ответ дан Kevin Smith 17 January 2019 в 17:00
поделиться

В дополнение к полезный ответ Кевина Смита :

  • Единственный способ передать массив в скрипт PowerShell через PowerShell CLI (powershell.exe; pwsh для PowerShell Core ) предназначен для использования -Commmand .

    • Напротив, -File интерпретирует аргументы как литеральные значения и не не распознает массивы, ссылки на переменные ($foo) , ...; в данном случае скрипт заканчивает тем, что видит единственную строку с буквальным содержанием hello,cat,Dog (из-за удаления двойных кавычек).
  • Из внутри PowerShell :

    • Используйте -Command с [ 1130] блок сценариев ({ ... }), как показано в ответе Кевина , который не только упрощает синтаксис (просто использует обычный синтаксис внутри блока), но и производит вывод с богатым типом (не только строки , как с другими внешними программами), поскольку целевой экземпляр PowerShell использует формат сериализации CLIXML для вывода своих результатов, которые сеанс вызова автоматически десериализует, так же, как работают удаленные / фоновые задания PowerShell (однако, как и в случае с последним, точность десериализации всегда ограничена).

    • Обратите внимание, однако, что изнутри PowerShell вам обычно не нужен CLI , который создает (дорогостоящий) дочерний процесс , и может просто вызовите *.ps1 файл сценария напрямую :

      • .\test.ps1 -one hello, cat, Dog
    • Из вне PowerShell - обычно cmd.exe / пакетный файл - используют -Command с одиночной строкой в ​​двойных кавычках [ 1162], содержащий код PowerShell для выполнения, учитывая, что использование блоков сценариев не поддерживается извне .

      • powershell -Command ".\test.ps1 -one hello, cat, Dog"

    Обратите внимание, что с -Command, так же как и с прямым вызовом внутри PowerShell, вы должны использовать [ 1114], а не просто test.ps1, чтобы выполнить файл с таким именем в текущем каталоге , который является функцией безопасности.

    Также обратите внимание, что с вашими простыми значениями аргументов, их включение "..." является необязательным, поэтому команды выше используют просто hello, cat, Dog вместо "hello", "cat", "Dog"; фактически используя встроенные " символы. в общей командной строке "..." может быть довольно сложно - см. этот ответ .

0
ответ дан mklement0 17 January 2019 в 17:00
поделиться
Другие вопросы по тегам:

Похожие вопросы: