Ask Chrome Ext: запуск, который открывает ссылку в той же вкладке - PullRequest
0 голосов
/ 14 апреля 2019
  • Я хочу сделать расширение для Chrome, что-то вроде запуска.
  • Когда щелкнуло расширение, оно показывает более строгую опцию (например, google, twitter и т. Д.).
  • Когда я нажимаюодин из вариантов, он направляет меня на правильный веб-сайт (когда вы нажимаете Google, вы перенаправлены на страницу Google) на той же странице / активной странице (например: я на странице github, когда я использую свое расширение и выбираю Google, он направляетэто на страницу Google на той же странице, а не на новой странице).
  • Он будет работать только на определенном веб-сайте (только на github, но не на другой странице).

Мой код пока

-manifest.Json

{
    "manifest_version":2,

    "name":"Test laucher",
    "description":"test launcher",
    "version":"1.0.0",
    "permissions": ["tabs", "*://*.github.com/*", "activeTab"],
    "browser_action":{
        "default_popup":"popup.html"
    },

    "content_scripts":[{ 
        "matches": ["*://*.github.com/*"],
        "js": ["contentz.js","js/jquery-3.3.1.js"]
    }],

    "icons":{
        "16":"icon-16.png",
        "48":"icon-48.png",
        "128":"icon-128.png"
    }
}

-popup.html

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>Vynica</title>
    <link rel="stylesheet" type="text/css" href="style.css" />
    <script src="contentz.js" type="text/javascript"></script>
    <script src="js/jquery-3.3.1.js"></script>
</head>
<body>
    <ul id="menu-v">
        <li id="web_google"><a >google</a></li>
        <li>
            <a  class="arrow">Social media</a>
            <ul>
                <li id="web_facebook"><a >Facebook</a></li>
                <li>
                    <a  class="arrow">Twitter</a>
                    <ul>
                        <li><a >a lalala</a></li>
                        <li><a >b lalala</a></li>
                        <li><a >c lalala</a></li>
                    </ul>
                </li>
                <li>
                    <a  class="arrow">Instagram</a>
                    <ul>
                        <li><a >a lalala</a></li>
                        <li><a >b lalala</a></li>
                        <li><a >c lalala</a></li>
                    </ul>
                </li>
            </ul>
        </li>
    </ul>
</body>
</html>

-contentz.js

function goToWebsite(urls){
    chrome.tabs.query({active: true, currentWindow: true}, function(tabs){
        var tab = tabs[0];
        chrome.tabs.update(tab.id, {url: urls});
    });
    window.close();
}

function loadMainContent(){

        $("#web_google").click(function(){
            goToWebsite("https://www.google.com/");
        });
        $("#web_facebook").click(function(){
            goToWebsite("https://www.facebook.com/")
        });
        $("#web_twitter").click(function(){
            goToWebsite("https://twitter.com/");
        });
}

-style.css

body {
  background-color: #63cdda ;
  margin-left:auto;
  margin-right:auto;
  width:800px
}

#web_google, #web_facebook{
  cursor: pointer;
}

ul#menu-v, #menu-v ul
{
    width:200px; /* Main Menu width */
    border:1px solid #CCCCCC;
    list-style:none; margin:0; padding:0;
    z-index:9;
}     

#menu-v li
{
    margin:0;padding:0;
    position:relative;    
    background-color:#EEEEEE; /*fallback color*/
    background-color:rgba(255,255,255,0.8);
    transition:background 0.5s;
}
#menu-v li:hover
{
    background-color:rgba(255,255,255,0.5);
}

#menu-v a
{
    font:normal 12px Arial;
    border-top:1px solid #CCCCCC;
    display:block;
    color:#444444;
    text-decoration:none;
    line-height:26px;
    padding-left:22px; 
    position:relative;           
}

#menu-v li:first-child a
{
    border-top:0;
}

#menu-v a.arrow::after{
    content:'';
    position:absolute;
    display: inline-flex;
    top:50%;
    margin-top:-4px;
    right:8px;
    border-width:4px;
    border-style:solid;
    border-color:transparent transparent transparent black;
    transition:border-color 0.5s;  
}

#menu-v li a.arrow:hover::after
{
    border-color:transparent transparent transparent red;
}

/*Sub level menu items
---------------------------------------*/
#menu-v li ul
{
    min-width:180px; /* Sub level menu min width */
    position:absolute;
    display:none;
    left:100%;
    top:0;
}

#menu-v li:hover > ul
{
    display:block;
}

Что-то не так со мной, код (особенно JS)?Или я подошел в неправильном направлении?Может ли кто-нибудь указать на мою ошибку?

Спасибо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...