我怎样才能推出一个网站,从一个按钮(How can I launch a website from

2019-10-19 18:46发布

我知道如何使用createAnchor放置链接面板,但是我想从一个按钮来启动的链接。 这是可能的,如果是的话怎么样?

Answer 1:

一些试错后,我发现实现这一目标的一个更简单的方法。 我刚刚创建按钮的图像显示我想要的文字,并使用锚thse的setAttribute方法。 Unfortunally我stll需要AbsolutePanel。

function doGet()
{ 
  // Problem with Google Apps :
  //    Not possible to click a Button and show a site
  //    Solutions found on StackOverflow mostly use :
  //       a) var panel  = createAbsolutePanel               --> Necessary to create an Absolute Panel
  //       b) var image  = createImage                       --> The image to be shown 
  //       c) var anchor = createAnchor                      --> Anchor making it possible to activate a url
  //       d) position the anchor on top of the image
  //       e) make anchor and image of same size
  //       f) make anchor invisible (by zIndex, opacity or visibility)
  //    
  //    One of the people showing how this works is http://stackoverflow.com/users/1368381/serge-insas who's
  //    efforts inspired me to have a look at other possibilities. (thanks !)
  //    
  //    Result     : next step in making it easy to overcome a limitation of GAS --> no createImage required anymore
  //    How        : using setAttribute('backgroundImage', Url)  method of anchor
  //    Limitation : still required to create an Absolute panel instead of a Vertical panel --> who's next to improve ??
  //
  //    Author     : SoftwareTester, may 13th, 2014

   var app = UiApp.createApplication().setTitle("Image Anchor");
   var picButton = 'https://drive.google.com/uc?id=0BxjtiwHnjnkrTVJiR1g2SlZTLVE'; // Can on be accessed be a few people
   var widthButton = 128;
   var heightButton = 24;
   var anchor = app.createAnchor("", "http://www.opasittardgeleen.nl")
                  .setHeight(heightButton).setWidth(widthButton)            
//                  .setHeight("150").setWidth("128")                         // Nice effect !!
//                  .setHeight("150").setWidth("512")                         // Even more 
                  .setStyleAttribute('backgroundImage', 'url(' + picButton + ')');

   var panel = app.createAbsolutePanel().setWidth('50%').setHeight('50%');
   panel.add(anchor,100,50);         // I would like to avoid positioning like this and just add the anchor to a Grid or VerticalPanel
   app.add(panel);  
   return app.close();
}


Answer 2:

我已经回答了类似的职位与工作很好,虽然是这样,我承认,关于它的功能有点复杂的一种解决办法...

这是一个测试应用程序

并从其他后再现的代码如下:我用叠加到图像的无形锚,但当然也可能是别的......你想有一个按钮或什么的。

function doGet(){
  var app = UiApp.createApplication().setStyleAttribute("background", "#CCCCFF").setTitle('Anchor Test')
  var top = '100PX';// define dimensions and position
  var left = '100PX';
  var width = '80PX';
  var height = '80PX';
  var mainPanel = app.createVerticalPanel();

  var customAnchor = app.createHorizontalPanel().setId('usethisId')
  addStyle(customAnchor,top,left,width,height,'1','1')

  var image = app.createImage("https://dl.dropbox.com/u/211279/Time-change-clock_animated_TR80.gif")
  addStyle(image,top,left,width,height,'1','1')

  var realAnchor = app.createAnchor('This is the Anchor', 'https://sites.google.com/site/appsscriptexperiments/home')  
  addStyle(realAnchor,top,left,width,height,'2','0')


  customAnchor.add(realAnchor);
  customAnchor.add(image)
  mainPanel.add(customAnchor);
  app.add(mainPanel);
  return app;
}

function addStyle(widget,top,left,width,height,z,visibility){
widget.setStyleAttributes( 
    {'position': 'fixed', 
     'top' : top,
     'left' : left,
     'width' : width, 
     'height':height,
     'opacity' : visibility,  
     'zIndex' : z});
   }  

编辑:我忘了提这个帖子有一个按钮,例如......你想要什么: 使用谷歌Apps脚本如何打开一个网络浏览器?


编辑2

继软件测试人员的回答,这里是一个紧凑的版本,人们可以在网格中放置或其他地方......只是地方叫“容器”窗口小部件。

为了说明我把它放在一个网格在下面的例子中/

链接测试

代码:

function doGet(){ 
  var app = UiApp.createApplication().setTitle("Image Anchor");
  var picButton = 'https://dl.dropboxusercontent.com/u/211279/ProgressSpinner.gif'; 
  var img = app.createImage(picButton).setPixelSize(25,25);
  var grid = app.createGrid(5,2);
  for(n=0;n<5;n++){
    grid.setText(n,0,'some text').setBorderWidth(1);
  }
  var anchor = app.createAnchor(" -  ", "https://sites.google.com/site/appsscriptexperiments/").setStyleAttribute('opacity','0').setPixelSize(25,25);
  var container = app.createAbsolutePanel().setPixelSize(25,25);
  container.add(img,0,0).add(anchor,0,0);
  grid.setWidget(4,1,container);
  app.add(grid);  
  return app;
}


Answer 3:

塞尔INSAS的答案EDIT 2提供使用网格额外的灵活性。

通过学习和利用每个人的好主意有点改善世界一点,也适用于过程的软件。 再次感谢塞尔!

我注意到一些差异,可能会或可能不会是在某些情况下兴趣。

我总是试图指定的常量(如widthheight ),并使用类似这样的代码减少.setPixelSize(width, height)使它更容易“不要忘记的东西,而改变”。 这就是为什么我宁愿避免创建一个单独的图像对象。

哔叽INSAS使用.setStyleAttribute('opacity','0'); 而我使用.setStyleAttribute('backgroundImage', url); 。 我不知道什么是亲的和这两种可能性反对的。

下面是通用代码

function doGet()
{ // Generalized version using : image + opacity + container
  var app       = UiApp.createApplication().setTitle("Image Anchor");
  var width     = 25;
  var height    = 25;
  var urlImage  = 'https://dl.dropboxusercontent.com/u/211279/ProgressSpinner.gif';
  var urlAnchor = "https://sites.google.com/site/appsscriptexperiments/";

  var grid      = createImageAnchor(urlImage, urlAnchor, width, height);

  app.add(grid);
  return app;
} 

并且功能createImageAnchor可以

function createImageAnchor(urlImage, urlAnchor, width, height)
{ // Using backgroundImage
   var app    = UiApp.getActiveApplication();

   var anchor = app.createAnchor("", urlAnchor).setPixelSize(width, height)
                   .setStyleAttribute('backgroundImage', 'url(' + urlImage + ')');

   var panel  = app.createAbsolutePanel().setPixelSize(width, height).add(anchor, 0, 0);
   var grid   = app.createGrid(1, 1).setWidget(0, 0, panel); // Create grid and put anchor in it

   return grid;   
}  

要么

function createImageAnchor(urlImage, urlAnchor, width, height)
{ // Using opacity
   var         = UiApp.getActiveApplication();

   var image   = app.createImage(urlImage).setPixelSize(width, height);
   var anchor  = app.createAnchor("", urlAnchor) .setPixelSize(width, height)
                    .setStyleAttribute('opacity','0');

   var panel   = app.createAbsolutePanel().setPixelSize(width, height)
                    .add(image, 0, 0).add(anchor, 0, 0);      // Same position for image and anchor
   var grid    = app.createGrid(1, 1).setWidget(0, 0, panel); // Create grid and put image + anchor in it

   return grid;   
}  

使用createImageAnchor可以更容易地在代码中使用这种“组合式目标”的任何地方,特别是将其添加到库中后。

由于我是新来GAS(始于5月7日5年后不活动)我知道我需要学习很多东西,想知道什么样的不同方法亲的和反对的是。



文章来源: How can I launch a website from a button