AddMedicalName.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722
  1. <template>
  2. <div>
  3. <crumbs :title="minTitle"
  4. :param="$route.params"
  5. linkTo="MedicalName"></crumbs>
  6. <div class="contents">
  7. <div class="content">
  8. <h3>添加术语:</h3>
  9. <p class="titl">医学标准术语:</p>
  10. <table class="deptbox" v-if="id == ''">
  11. <tr>
  12. <td class="ind">序号</td>
  13. <td>标准词<span class="necess">*</span></td>
  14. <td>拼音</td>
  15. <td>类型<span class="necess">*</span></td>
  16. <td class="desc">说明</td>
  17. </tr>
  18. <tr>
  19. <td class="ind">1</td>
  20. <td :title="data.name&&data.name.length>9?data.name:''">
  21. <!-- 修改时标准词不能修改,修改了会当做新增处理 4-17 -->
  22. <p v-if="id">{{data.name}}</p>
  23. <!-- 4-18 需求变更 -->
  24. <input v-else type="text" v-model="data.name" placeholder="请输入术语" maxlength="50" @blur="handleBlur(1)">
  25. </td>
  26. <td>
  27. <input type="text" v-model="data.spell" placeholder="请输入拼音" maxlength="50" @input="handlePinyin">
  28. </td>
  29. <td>
  30. <!-- <el-select v-if="!id" v-model="data.type" filterable placeholder="请选择" size="small" @change="selectType">
  31. <el-option
  32. v-for="item in typeList"
  33. :key="item.id"
  34. :label="item.name"
  35. :value="item.name">
  36. </el-option>
  37. </el-select> -->
  38. <template v-if="!id">
  39. <el-select v-model="data.type" filterable clearable placeholder="请选择" size="small" @change="selectType">
  40. <el-option-group
  41. v-for="group in options"
  42. :key="group.label">
  43. <el-option
  44. v-for="item in group.options"
  45. :key="item.id"
  46. :label="item.name"
  47. :value="item.name">
  48. </el-option>
  49. </el-option-group>
  50. </el-select>
  51. </template>
  52. <span v-else>{{data.type}}</span>
  53. </td>
  54. <td class="desc">
  55. <input v-model="data.remark" placeholder="请输入术语说明" maxlength="120"></input>
  56. </td>
  57. </tr>
  58. </table>
  59. <div class="deptboxChange" v-else>
  60. <table class="deptbox deptboxTable">
  61. <tr>
  62. <td class="ind">序号</td>
  63. <td>术语</td>
  64. <td>拼音</td>
  65. <td>类型</td>
  66. <td class="desc">说明</td>
  67. <td class="descs">术语性质</td>
  68. <td v-if="id">操作</td>
  69. </tr>
  70. <tr v-for="(item,index) in allwords">
  71. <td class="ind">{{index+1}}</td>
  72. <td :title="item.name&&item.name.length>9?item.name:''">
  73. <!-- 使用原生input,输入限制 -->
  74. <!-- <el-input v-model="item.name" placeholder="请输入术语" maxlength="30" size="small" @input.native="handleInput(2,index)"></el-input> -->
  75. <input type="text" v-model="item.name" :title="item.name" placeholder="请输入术语" maxlength="50" @blur="handleBlur(2,index,99)" >
  76. </td>
  77. <!-- <td v-if="!item.isEdit">
  78. {{item.spell}}
  79. </td>
  80. <td v-else> -->
  81. <td>
  82. <input type="text" v-model="item.spell" placeholder="请输入拼音" maxlength="50" @input="handlePinyin" class="spell">
  83. </td>
  84. <td>
  85. <!-- {{data.type}} -->
  86. <template v-if="index==0&&copy">
  87. <el-select v-model="data.type" filterable placeholder="请选择" size="small" @change="selectType">
  88. <el-option-group
  89. v-for="group in options"
  90. :key="group.label">
  91. <el-option
  92. v-for="item in group.options"
  93. :key="item.id"
  94. :label="item.name"
  95. :value="item.name">
  96. </el-option>
  97. </el-option-group>
  98. </el-select>
  99. </template>
  100. <span v-else>{{data.type}}</span>
  101. </td>
  102. <td class="desc">
  103. <input v-model="item.remark" placeholder="请输入术语说明" maxlength="120"></input>
  104. </td>
  105. <td class="desc">
  106. {{item.isConcept == 1?"标准词":"同义词"}}
  107. </td>
  108. <td v-if="id">
  109. <span class="displayColor" v-if="item.isConcept == 1">删除</span>
  110. <span @click="deleLine(index,55)" class="delete" v-else>删除</span>
  111. </td>
  112. </tr>
  113. <tr @click="addSpan(55)">
  114. <td colspan="7" class="addSpan">+</td>
  115. </tr>
  116. </table>
  117. <div class="actionDo">
  118. <!-- <div class="btnWrap"> -->
  119. <!-- <el-button type="primary" size="mini" v-if="show" @click="comfirn(14)">确认修改</el-button> -->
  120. <!-- <el-button plain size="mini" v-if="show" @click="toggleShow(1)">放弃修改</el-button>
  121. <el-button plain size="mini" @click="toggleShow(2)" v-if="!show">修改标准词</el-button> -->
  122. <!-- </div> -->
  123. <div class="radioWrap" v-if="show">
  124. <el-radio-group v-model="radioVal" size="mini">
  125. <el-radio v-for="(item,index) in allwords" :label="index" :disabled="index == 0">选为标准词</el-radio>
  126. </el-radio-group>
  127. </div>
  128. </div>
  129. </div>
  130. <p class="titl" v-if="id == ''">同义词:</p>
  131. <table class="deptbox" v-if="id == ''">
  132. <tr>
  133. <td class="ind">序号</td>
  134. <td>术语</td>
  135. <td>拼音</td>
  136. <td>类型</td>
  137. <td class="desc">说明</td>
  138. <td v-if="id">操作</td>
  139. </tr>
  140. <tr v-for="(item,index) in synonymous">
  141. <td class="ind">{{index+1}}</td>
  142. <td :title="item.name&&item.name.length>9?item.name:''">
  143. <!-- 使用原生input,输入限制 -->
  144. <!-- <el-input v-model="item.name" placeholder="请输入术语" maxlength="30" size="small" @input.native="handleInput(2,index)"></el-input> -->
  145. <input type="text" v-model="item.name" placeholder="请输入术语" maxlength="50" @blur="handleBlur(2,index)">
  146. </td>
  147. <td>
  148. <input type="text" v-model="item.spell" placeholder="请输入拼音" maxlength="50" @input="handlePinyin">
  149. </td>
  150. <td>
  151. {{data.type}}
  152. </td>
  153. <td class="desc">
  154. <input v-model="item.remark" placeholder="请输入术语说明" maxlength="120"></input>
  155. </td>
  156. <td v-if="id">
  157. <span @click="deleLine(index)" class="delete">删除</span>
  158. </td>
  159. </tr>
  160. <tr @click="addSpan">
  161. <td :colspan="colspan" class="addSpan">+</td>
  162. </tr>
  163. </table>
  164. <div class="moreInfo" v-if="showMore==1">
  165. <p>更多信息:</p>
  166. <el-form>
  167. <el-form-item label="性别:">
  168. <el-select v-model="sexType">
  169. <el-option v-for="(it,i) in sex" :label="it.name" :value="it.name"></el-option>
  170. </el-select>
  171. </el-form-item>
  172. <el-form-item label="年龄:" class="ages">
  173. <el-input
  174. v-model.number="minAge"
  175. type="number"
  176. @input="inputAge">
  177. </el-input>
  178. <span class="ageLine">~</span>
  179. <el-input
  180. v-model.number="maxAge"
  181. type="number"
  182. @input="inputAge"
  183. ></el-input>
  184. </el-form-item>
  185. </el-form>
  186. </div>
  187. <div class="btn">
  188. <el-button
  189. type="primary"
  190. :disabled = 'saveDisable'
  191. @click="comfirn"
  192. >确 定</el-button>
  193. </div>
  194. </div>
  195. </div>
  196. </div>
  197. </template>
  198. <script type="text/javascript">
  199. import api from '@api/icss.js';
  200. import pinyin from '../../js/Convert_Pinyin.js';
  201. export default {
  202. name:'AddMedicalName',
  203. data(){
  204. return{
  205. minTitle:'医学术语命名维护-添加',
  206. data:{
  207. name:'',
  208. type:'',
  209. remark:'',
  210. isConcept:1,
  211. spell:''
  212. },
  213. radioVal:'',
  214. typeList:[],
  215. id:'',
  216. synonymous:[],//同义词
  217. singleword:[],
  218. allwords:[],//标准词和同义词
  219. colspan:5,
  220. colspans:6,
  221. currentPage:1,
  222. pageSize:10,
  223. show:false,
  224. tmpSynonymous:[],
  225. sexType:'通用',
  226. maxAge:200,
  227. minAge:0,
  228. showMore:'',
  229. sex:[
  230. {
  231. name:'通用',
  232. value:3
  233. },
  234. {
  235. name:'男',
  236. value:1
  237. },
  238. {
  239. name:'女',
  240. value:2
  241. }
  242. ],
  243. unfit:false, //点确认时是否弹提示,
  244. saveDisable: false, //保存按钮禁止点击
  245. options:[],
  246. copy:null
  247. }
  248. },
  249. created(){
  250. this.getTypeList();
  251. const id = this.$route.params.id || '';
  252. const copy = this.$route.params.copy || '';
  253. this.copy = copy;
  254. if(id){
  255. this.minTitle = copy?'医学术语命名维护-复制':'医学术语命名维护-修改';
  256. this.id = id;
  257. this.colspan = 5;
  258. this.getDetail(id);
  259. }
  260. },
  261. watch:{
  262. radioVal(newVal,preVal){
  263. if(newVal && newVal != preVal){
  264. this.changeState(newVal);
  265. }
  266. }
  267. },
  268. methods:{
  269. changeState(val){
  270. let tmpAllwords = JSON.parse(JSON.stringify(this.synonymous));
  271. for(let i = 0;i < tmpAllwords.length;i++){
  272. if(i+1 == val){
  273. tmpAllwords[i].isConcept = 1
  274. tmpAllwords[i].type = this.data.type
  275. }else{
  276. tmpAllwords[i].isConcept = 0
  277. }
  278. }
  279. this.tmpSynonymous = tmpAllwords
  280. this.synonymous = tmpAllwords
  281. },
  282. toggleShow(num){
  283. let tmpShow = this.show
  284. this.show = !tmpShow
  285. if(num == 1){
  286. this.changeState(-1)
  287. this.radioVal = ''
  288. }
  289. },
  290. getDetail(ids){
  291. if(ids){
  292. api.getMedicalDetail({'conceptId':ids}).then((res)=>{
  293. const result = res.data;
  294. if(result.code == 0){
  295. this.data = result.data.libName[0];
  296. this.singleword = result.data.libName;
  297. this.synonymous = result.data.otherNames;
  298. this.allwords = (result.data.libName).concat(result.data.otherNames);
  299. this.showMore = result.data.isHasCommon;
  300. this.maxAge = result.data.maxAge;
  301. this.minAge = result.data.minAge;
  302. // this.sexType = result.data.sexType;
  303. let sexType = result.data.sexType;
  304. this.sex.map((v,i)=>{
  305. if(v.value==sexType){
  306. this.sexType = v.name;
  307. }
  308. })
  309. }else{
  310. this.$message({
  311. message:result.msg,
  312. type:'warning'
  313. });
  314. }
  315. })
  316. }
  317. },
  318. getTypeList(){
  319. api.allKnowledgeType({'name':''}).then((res)=>{
  320. const data = res.data;
  321. if(data.code==0){
  322. // this.typeList = data.data.records;
  323. this.typeList = data.data;
  324. // 类型改成平铺
  325. if(data.data.length>0){
  326. const total = data.data.length;
  327. const average = parseInt(total/3);
  328. const mod = total%3; //余数
  329. const firstGroup = data.data.slice(0,average);
  330. let secGroup = [];
  331. let thirdGroup = [];
  332. if(mod == 2){
  333. secGroup = data.data.slice(average,average*2+1);
  334. thirdGroup = data.data.slice(average*2+1,total);
  335. }else{
  336. secGroup = data.data.slice(average,average*2);
  337. thirdGroup = data.data.slice(average*2,total);
  338. }
  339. this.options.push({label:1,options:firstGroup},{label:2,options:secGroup},{label:3,options:thirdGroup});
  340. }
  341. }else{
  342. this.$message({
  343. message:data.msg,
  344. type:'warning'
  345. });
  346. }
  347. }).catch((error) => {
  348. console.log(error);
  349. });
  350. },
  351. // handleInput(index,name){
  352. /* handleInput(type,index){
  353. // 可输入内容:字母、数字、汉字、特殊字符:% —— 其余不可输入;
  354. // if(!name){//标准词输入
  355. if(type==1){//标准词输入
  356. this.data.name = this.data.name.replace(/[^%0-9a-zA-Z\u4e00-\u9fa5]/g,'');
  357. }else{
  358. this.synonymous[index].name = this.synonymous[index].name.replace(/[^%0-9a-zA-Z\u4e00-\u9fa5]/g,'');
  359. }
  360. },*/
  361. handleBlur(type,index,flg){
  362. // 不能为纯数字、纯字符、纯数字加字符 4-18
  363. // const pattern = /[^~@#$%^&*_\-+=,,.。::"“??”;;、!!0-9]/g;
  364. // 需求更改:不能为纯数字,其余均可输入 5-20
  365. const pattern = /[^0-9]/g;
  366. if(type==1){//标准词输入
  367. if(this.data.name && !pattern.test(this.data.name)){
  368. this.$message({
  369. // message:'无法输入纯数字或者纯字符,请输入正确数据!',
  370. message:'无法输入纯数字,请输入正确数据!',
  371. type:'warning'
  372. });
  373. // this.data.name = '';
  374. this.unfit = true;
  375. }else{
  376. let data = this.data;
  377. data.spell = pinyin.getCamelChars(data.name);
  378. this.unfit = false;
  379. }
  380. }else if(type==2){
  381. // 修改时术语名称、拼音和类型均不能修改
  382. if(flg == 99){
  383. // if(this.synonymous[index-1].name && !pattern.test(this.synonymous[index-1].name)){
  384. if(this.allwords[index].name && !pattern.test(this.allwords[index].name)){
  385. this.$message({
  386. message:'无法输入纯数字,请输入正确数据!',
  387. type:'warning'
  388. });
  389. // this.synonymous[index-1].name = '';
  390. this.unfit = true;
  391. }else{
  392. // let current = this.synonymous[index-1];
  393. let current = this.allwords[index];
  394. current.spell = pinyin.getCamelChars(current.name);
  395. this.unfit = false;
  396. }
  397. }else{
  398. if(this.synonymous[index].name && !pattern.test(this.synonymous[index].name)){
  399. this.$message({
  400. message:'无法输入纯数字,请输入正确数据!',
  401. type:'warning'
  402. });
  403. // this.synonymous[index].name = '';
  404. this.unfit = true;
  405. }else{
  406. let current = this.synonymous[index];
  407. current.spell = pinyin.getCamelChars(current.name);
  408. this.unfit = false;
  409. }
  410. }
  411. }
  412. },
  413. handlePinyin(e){//只能输入英文
  414. e.target.value = e.target.value.replace(/[^a-zA-Z]/g,'');
  415. },
  416. addSpan(type){
  417. let singleSpan = {
  418. name:'',
  419. remark:'',
  420. isConcept:0,
  421. isEdit:true,
  422. spell:null
  423. }
  424. if(type == 55){
  425. this.allwords.push(singleSpan);
  426. this.synonymous.push(singleSpan);
  427. }else{
  428. this.synonymous.push(singleSpan);
  429. }
  430. },
  431. warning(msg,type){
  432. this.$message({
  433. showClose: true,
  434. message:msg,
  435. type:type||'warning'
  436. })
  437. },
  438. showConfirmDialog(msg,resolve){
  439. this.$alert(msg, '提示', {
  440. confirmButtonText: '确定',
  441. type: 'warning'
  442. }).then(() => {
  443. resolve();
  444. }).catch(() => {});
  445. },
  446. deleLine(index,type){
  447. // 只在界面删除数据,待点确认 后参才真正删除
  448. if(type == 55){
  449. this.synonymous.splice(index-1,1);
  450. this.allwords.splice(index,1);
  451. }else{
  452. this.synonymous.splice(index,1);
  453. }
  454. },
  455. comfirn(flg){
  456. if(!this.data.name){
  457. this.warning('请输入标准词');
  458. return
  459. }
  460. if(!this.data.type && !this.unfit){
  461. this.warning('请选择术语类型');
  462. return
  463. }
  464. // 处于修改标准词状态且没有选中,不能保存
  465. if(this.show && !this.radioVal){
  466. this.warning('请先选择标准词');
  467. return
  468. }
  469. // 年龄为必填项--2019-6-5需求
  470. if(this.showMore == 1){
  471. if(!this.minAge && this.minAge != 0 || !this.maxAge){
  472. this.warning('年龄不能为空,区间为0-200');
  473. return
  474. }
  475. if(this.minAge < 0 || this.minAge > 200 || this.maxAge < 0 || this.maxAge > 200){
  476. this.warning('年龄必须是0-200');
  477. return
  478. }
  479. }
  480. // 过滤同义词空数据
  481. let realData=[];
  482. if(this.id){//修改用暂存的列表
  483. realData = this.synonymous.filter((item)=>{
  484. return item.name;
  485. })
  486. let tmpArr = []
  487. for(let k = 0;k < realData.length;k++){
  488. if(realData[k].isConcept == 1){
  489. let tmpdata = JSON.parse(JSON.stringify(this.data))
  490. tmpArr.push(realData[k])
  491. realData.splice(k,1)
  492. tmpdata.isConcept = 0
  493. realData.push(tmpdata)
  494. this.data = tmpArr[0]
  495. }
  496. }
  497. }else{
  498. realData = this.synonymous.filter((item)=>{
  499. return item.name;
  500. })
  501. }
  502. let detailList = [];
  503. detailList[0] = this.data;
  504. for(let i=0; i<realData.length; i++){
  505. realData[i].type = this.data.type;
  506. detailList.push(realData[i]);
  507. }
  508. // 校验是否有名称全为数字
  509. const pattern = /[^0-9]/g;
  510. for(let d=0; d<detailList.length; d++){
  511. let dname = detailList[d].name;
  512. // if(detailList[d].name && !pattern.test(detailList[d].name)){
  513. if(dname && !dname.match(pattern)){
  514. if(!this.unfit){//避免和失焦事件同事弹出
  515. this.$message({
  516. message:'无法输入纯数字,请输入正确数据!',
  517. type:'warning'
  518. });
  519. }
  520. this.unfit = false;
  521. return false;
  522. break
  523. }
  524. }
  525. let params;
  526. if(this.showMore==1){
  527. // 下拉文字转code
  528. let sexCode;
  529. this.sex.map((v,i)=>{
  530. if(v.name==this.sexType){
  531. sexCode = v.value;
  532. }
  533. })
  534. params = {
  535. 'name':this.data.name,
  536. 'type':this.data.type,
  537. 'detailList':detailList,
  538. 'conceptId':this.copy?'':this.id,//复制当新增,把id置空
  539. 'sexType':sexCode,
  540. 'maxAge':this.maxAge,
  541. 'minAge':this.minAge
  542. }
  543. }else{
  544. params = {
  545. 'name':this.data.name,
  546. 'type':this.data.type,
  547. 'detailList':detailList,
  548. 'conceptId':this.copy?'':this.id
  549. }
  550. }
  551. this.saveDisable = true //提交保存按钮不可点击,返回结果时才可点击,防止频繁发送请求
  552. api.addMedicalName(params).then((res)=>{
  553. const result = res.data;
  554. if(result.code==0){
  555. this.warning(res.data.msg||'操作成功','success');
  556. //返回带搜索条件的首页
  557. this.$router.push({name:'MedicalName',params:Object.assign({},this.$route.params,{currentPage:1})});
  558. /*if(flg == 14){
  559. this.getDetail(this.id)
  560. this.radioVal = ''
  561. this.show = false
  562. }else{
  563. this.$router.push({name:'MedicalName'});
  564. }*/
  565. }else{
  566. this.warning(res.data.msg);
  567. }
  568. this.saveDisable = false
  569. })
  570. },
  571. inputAge(){
  572. // console.log("输入年龄")
  573. },
  574. selectType(e){
  575. this.typeList.map((v,i)=>{
  576. if(v.name==e){
  577. this.showMore = v.isHasCommon;
  578. }
  579. })
  580. }
  581. }
  582. }
  583. </script>
  584. <style lang="less" scoped>
  585. @import "../../less/admin.less";
  586. /deep/ .radioWrap .el-radio {
  587. display: block;
  588. height: 41px;
  589. line-height: 41px;
  590. text-align: right;
  591. margin-left: 0;
  592. }
  593. // 饿了么分组下拉
  594. .el-scrollbar{
  595. .el-select-dropdown__list{
  596. .el-select-group__wrap{
  597. min-width: 160px !important;
  598. display: inline-block !important;
  599. vertical-align: top !important;
  600. }
  601. }
  602. }
  603. .el-select-group__wrap::after{
  604. background:#fff !important;
  605. }
  606. .displayColor {
  607. color: #ccc;
  608. cursor:not-allowed;
  609. }
  610. .delete {
  611. cursor: pointer;
  612. }
  613. .content{
  614. background: #fff;
  615. padding: 20px 20px 30px;
  616. color: #545455;
  617. }
  618. .titl{
  619. margin: 25px 0 10px;
  620. }
  621. .deptbox{
  622. // width: 100%;
  623. background: #fff;
  624. padding: 20px 10px 30px;
  625. font-size: 14px;
  626. text-align: left;
  627. border-collapse: collapse;
  628. >tr{
  629. height: 30px;
  630. text-align: center;
  631. td{
  632. width: 135px;
  633. border: 1px solid #666;
  634. padding:5px;
  635. }
  636. input{
  637. border:none;
  638. border: 1px solid #ccc;
  639. width: 100%;
  640. height: 30px;
  641. padding: 0 7px;
  642. box-sizing: border-box;
  643. border-radius: 4px;
  644. }
  645. .ind{
  646. width: 55px;
  647. }
  648. .desc{
  649. width: 280px;
  650. }
  651. .descs{
  652. width: 50px;
  653. }
  654. }
  655. .addSpan{
  656. text-align: center;
  657. cursor: pointer;
  658. }
  659. }
  660. .deptboxTable {
  661. width: 100%;
  662. }
  663. .deptboxChange {
  664. padding-right: 210px;
  665. position: relative;
  666. }
  667. .actionDo {
  668. width: 200px;
  669. position: absolute;
  670. top: 1px;
  671. right: 0;
  672. .btnWrap {
  673. height: 30px;
  674. }
  675. }
  676. .btn {
  677. text-align: right;
  678. margin-top: 20px;
  679. }
  680. .necess{
  681. display: inline-block;
  682. vertical-align: middle;
  683. color: red;
  684. margin-left: 2px;
  685. }
  686. .moreInfo{
  687. border-top: 1px solid #c0c4cc ;
  688. margin-top: 45px;
  689. p{
  690. margin:15px 0;
  691. }
  692. }
  693. .spell{
  694. text-align: center;
  695. }
  696. /deep/.ages{
  697. margin-top: 20px;
  698. .el-input {
  699. display: inline-block;
  700. width: auto;
  701. .el-input__inner {
  702. width: 60px;
  703. padding: 0 5px;
  704. text-align: center;
  705. }
  706. .el-input__inner::-webkit-outer-spin-button,
  707. .el-input__inner::-webkit-inner-spin-button {
  708. -webkit-appearance: none;
  709. }
  710. .el-input__inner[type="number"] {
  711. -moz-appearance: textfield;
  712. }
  713. }
  714. .ageLine{
  715. display: inline-block;
  716. margin: 0 35px;
  717. }
  718. }
  719. </style>