Definindo dinamicamente o atributo src do iframe no AngularJS
Ao trabalhar com iframes no AngularJS, muitas vezes é necessário definir o atributo src dinamicamente com base em um variável. No entanto, tentar fazer isso com atribuição padrão pode resultar na renderização de um atributo src vazio no iframe.
Compreendendo o problema e a solução
O problema surge ao tentar para definir o atributo src com uma URL não confiável. AngularJS implementa medidas de segurança para evitar possíveis ataques XSS (cross-site scripting). Para mitigar isso, o serviço $sce (Strict Contextual Escaping) precisa ser empregado para "confiar" na URL antes de atribuí-la.
O método trustAsResourceUrl() do serviço $sce pode ser usado para marcar explicitamente um URL como confiável, garantindo que ele possa ser usado com segurança em um modelo AngularJS.
Implementação de código
No arquivo controllers/app.js fornecido, injete o $sce service no AppCtrl e modifique a função setProject() da seguinte forma:
$scope.setProject = function (id) {
$scope.currentProject = $scope.projects[id];
$scope.currentProjectUrl = $sce.trustAsResourceUrl($scope.currentProject.url);
}
No modelo HTML, atualize o atributo src do iframe para fazer referência à variável currentProjectUrl:
Explicação
Ao chamar trustAsResourceUrl(), o URL é marcado como confiável e pode ser usado com segurança no modelo AngularJS. A diretiva ng-src definirá o atributo src do iframe com o URL confiável.
Notas adicionais
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3