Изображение CSS не отображается (Google AppScript) - PullRequest
0 голосов
/ 25 октября 2018

Я реализовал панель загрузки, которая показывает, что в то время как мой скрипт работает в фоновом режиме в Google Sheets, почти все элементы, используемые в CSS, на самом деле работают должным образом, единственное, что не работает, это изображение, которое должно быть вцентр полосы загрузки.

Я узнал, как на самом деле реализовать CSS в Google Appscript здесь CSS с помощью Google App Script .Но всякий раз, когда я использую background-image: url (myimage.png); изображение не отображается на панели загрузки.

CSS

<!DOCTYPE html>
<html lang="es">
<head>
    <link rel="shortcut icon" href="../assets/images/ico/favicon.ico" />
    <meta name="sitedomain" content="www.sdfsd.com.mx" />
    <meta name="country" content="Am" />
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="">
    <meta name="author" content="">
    <link rel="stylesheet" type="text/css" href="loader.css"/>
</head>
    <body>  
    <style>
    .text-loader {
    font-family: Arial, sans-serif;
    font-size: 20px;
} 

.loader-align {
    width:100%; 
    height:100%; 
    margin: 0 auto;
}

.center {
    text-align: center;
}

.dextra-d {
    background-image: url(d_icon.png);
    background-repeat: no-repeat; 
    background-position: center;
}

@keyframes lds-double-ring {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-webkit-keyframes lds-double-ring {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes lds-double-ring_reverse {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(-360deg);
    transform: rotate(-360deg);
  }
}
@-webkit-keyframes lds-double-ring_reverse {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(-360deg);
    transform: rotate(-360deg);
  }
}
.lds-double-ring {
  position: relative;
}
.lds-double-ring div {
  position: absolute;
  width: 160px;
  height: 160px;
  top: 20px;
  left: 20px;
  border-radius: 50%;
  border: 8px solid #000;
  border-color: #1d3f72 transparent #1d3f72 transparent;
  -webkit-animation: lds-double-ring 2.6s linear infinite;
  animation: lds-double-ring 2.6s linear infinite;
}
.lds-double-ring div:nth-child(2) {
  width: 140px;
  height: 140px;
  top: 30px;
  left: 30px;
  border-color: transparent #5699d2 transparent #5699d2;
  -webkit-animation: lds-double-ring_reverse 2.6s linear infinite;
  animation: lds-double-ring_reverse 2.6s linear infinite;
}
.lds-double-ring {
  width: 200px !important;
  height: 200px !important;
  -webkit-transform: translate(-100px, -100px) scale(1) translate(100px, 100px);
  transform: translate(-100px, -100px) scale(1) translate(100px, 100px);
}

    
    </style>
         
<div class="center">
    <div class="dextra-d">
    <div class="lds-double-ring loader-align">
        <div></div>
        <div></div>
    </div>
        </div>
 <span class="text-loader">Cargando entrevista...</span>   
</div>     
        </body>
</html>
<!DOCTYPE html>
<html>
<head>
<base target="_top">
</head>
<body>
<?!= include('LoadBar'); ?>
<script>
if (<?= close ?> == "close"){
google.script.host.close();
}
</script>
</body>
</html>

Ответы [ 3 ]

0 голосов
/ 25 октября 2018

Я думаю, что ваш путь неправильный.Я предполагаю, что он может быть расположен в ../assets/images/ на этом пути.

0 голосов
/ 25 октября 2018

попробуйте это:

<script>
window.onload=function(){
    google.script.run
    .withSuccessHandler(function(url){
       var s='<style type="text/css"> .myimage{ background-image:url("' + url + '");background-repeat:no-repeat;background-position:center;width:100%;height:100px;} </style>';
       $(s).appendTo("head");
       console.log('URI:\n%s\n',url);//I needed this to debug it because I left the last parenthesis off at first.
    })
    .convImageUrl();
  };
</script>

Я получил большую часть этого от Курт

И это функция в Code.gs:

function convImageUrl(url){//need to add a default logo here
  var url=url || "some default image url";
  var blob=UrlFetchApp.fetch(url).getBlob();
  var b64Url='data:' + blob.getContentType() + ';base64,' + Utilities.base64Encode(blob.getBytes());
  return b64Url;
}

Я получил большую часть convImageUrl () от Tanaike

Это способ вставить все изображение в URL.Вы можете сохранить его в приложении в виде строки.Вы можете поместить его в свой css background-image: url ("b64Url-string")

Я недавно поиграл с этим, и вот способ сохранить изображения в файлах.Я должен был сделать это, потому что существует ограничение в 50 000 символов для ячеек в листах.Функция проверяет, существуют ли они уже и, если они это делают, просто возвращает данные для файла хранилища.

function saveImageUrlInFile(imagename,content) {
  if(imagename) {
    var filename=imagename.slice(0,imagename.indexOf('.'));
    var folder=DriveApp.getFolderById('FolderId');
    var files=folder.getFilesByName(filename)
    var n=0;
    var file;
    while(files.hasNext()) {
      file=files.next();
      n++;
    }
    if(n==0){
      var f=folder.createFile(filename,content,MimeType.PLAIN_TEXT);
      return {name:f.getName(),id:f.getId()};
    }else{
      return {name:file.getName(),id:file.getId()};
    }
  }
}
0 голосов
/ 25 октября 2018

Попробуйте поставить "" на URL изображения.

background-image: url("d_icon.png");
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...