私はコンソールエラーの原因を理解するのに苦労しています。現在のところ、動作は破られていませんが、エラーは不安です。編集中のスパンで.blur()をトリガーすると、エラーが発生します。element.blur()によりUncaught TypeErrorが発生しました:elem.getAttributeは関数ではありません
ディレクティブのhtml:
<span ng-if="!time">{{ value }}</span>
<button class="btn btn-primary delink"
ng-if="delinkable && delinkVisable"
ng-click="resource.delink()">Not speaking</button>
<span ng-if="time">{{ value | momentFormat }}</span>
<div ng-if="time && datepicker" class="dropdown" id="datepicker">
<ul class="dropdown-menu" role="menu" aria-labelledby="dLabel">
<datetimepicker ng-model="resource.MeetingDateTime"
data-on-set-time="updateResource()"
data-datetimepicker-config="{ dropdownSelector: '#dropdown2' }">
</datetimepicker>
</ul>
<a class="dropdown-toggle" id="dropdown2" role="button" data-disabled="true"
data-toggle="dropdown" data-target="#" href>
<div class="input-group">
<span class="input-group-addon"><i class="fa fa-calendar"></i></span>
</div>
</a>
関連リンク機能:jqueryのは、 "::1451キャッチされない例外TypeError elem.getAttributeは関数ではありませんjquery.jsを" 文句
function handleChanges() {
var editSpan = angular.element(element.children()[0]);
var newValue;
if (scope.time) {
newValue = dates.makeDateTime(editSpan.text());
if (newValue) {
scope.resource[scope.property] = newValue;
newValue = editSpan.text();
} else {
editSpan.text(oldValue);
newValue = editSpan.text();
scope.resource[scope.property] = dates.makeDateTime(editSpan.text());
scope.datepicker = true;
$('#dropdown2').trigger('click');
scope.$digest();
}
} else {
scope.resource[scope.property] = editSpan.text();
newValue = editSpan.text();
}
if (newValue !== oldValue) {
scope.updateResource();
compileElement();
} else {
if (scope.time) {
hideDatepicker();
}
}
}
function bindEvents() {
var editSpan = angular.element(element.children()[0]);
editSpan.on('blur', function() {
editSpan.attr('contentEditable', false);
editSpan.unbind('keydown');
editSpan.unbind('blur');
scope.editing = false;
handleChanges();
});
editSpan.on('keydown', function(event){
if (event.keyCode == 27) {
event.preventDefault();
editSpan.text(oldValue);
editSpan.blur(); //The error seems to happen after this call
} else if (event.keyCode == 13) {
editSpan.blur(); //and after this call
} else if (scope.deleteable && event.keyCode == 8) {
if (editSpan.text().length == 0 || event.ctrlKey) {
scope.delete();
}
}
});
}
私は、.on( 'blur')とblur()との衝突があると思います。 keydownが実行されているときにぼかしがあり、 "editspan.blur()"に他のぼかしがあります。 –
したがって、あなたの問題は、ぼかしのコールバックで起こっている可能性が最も高いです: 'editSpan.attr( 'contentEditable'、false);'。まず、editSpanをログに記録し、それがあなたが思う要素であることを確認します。要素ノードではなく、テキストノードであれば、エラーを説明します。 –
私はeditSpan.attr(...)の直前でデバッグしました。editSpanはjqueryオブジェクトです。 – AdamCooper86