为了账号安全,请及时绑定邮箱和手机立即绑定

Angularjs设置textarea内的默认内容

Angularjs设置textarea内的默认内容

莫回无 2019-04-19 15:58:55
有个比较奇葩的需求。。就是在鼠标未选中textarea时文本框内会有一行灰色的提示语。这个很简单,用和value,placeholder什么的就能实现了。但是点击选中textarea也就是开始输入内容时,textarea内要有一行默认填入的内容。。没有图,我就用格式来解释一下。【#我是默认标题#我是placeholder】-->未选中textarea之前它显示的内容。【#我是默认标题#】-->选中textarea后文本框内的内容,placeholder消失但是默认标题保留。请问这样的功能要怎么样实现?
查看完整描述

2 回答

?
慕桂英4014372

TA贡献1871条经验 获得超13个赞

#html
ng-model="content"
placeholder="{{placeholder}}"
ng-focus="focus()"
ng-blur="blur()">
#js
angular.module('app',[])
.controller('DemoCtrl',function($scope){
vardefaultTitle='#我是默认标题#';
vardefaultPlaceholder='我是placeholder';
$scope.placeholder=defaultTitle+''+defaultPlaceholder;
$scope.content='';
$scope.focus=function(){
if(!$scope.content){
$scope.content=defaultTitle;
}
};
$scope.blur=function(){
if($scope.content===defaultTitle){
$scope.content='';
}
};
})
                            
查看完整回答
反对 回复 2019-04-19
?
拉丁的传说

TA贡献1789条经验 获得超8个赞

感觉你这个问题还是做成指令比较好,下面就是我的基本实现吧。
html
varapp=angular.module('app',[]);
app.directive('myTextarea',function(){
return{
require:'ngModel',
link:function(scope,ele,attrs,modelController){
vartext=attrs.myTextarea;
varplaceholder=attrs.placeholder;
varalltext=text+''+placeholder;
ele.attr('placeholder',alltext);
ele.on('focus',function(){
if(!modelController.$modelValue){
setVal(text);
}
});
ele.on('blur',function(){
if(modelController.$modelValue===text){
setVal('');
}
});
functionsetVal(v){
modelController.$setViewValue(v);
modelController.$render();
}
}
}
});
app.controller('main',['$scope',function($scope){
$scope.log=function(){
console.log($scope.myText)
}
}]);
基本思路就是通过model的controller来操控。
                            
查看完整回答
反对 回复 2019-04-19
慕课专栏
更多

添加回答

了解更多

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信