शक्ति और निर्भरता बनाम निर्भरता


159

मैंने 'यो कोणीय' चलाया और बाद में महसूस किया कि यह 1.0.8 स्थापित है, मैंने कोणीय घटकों की स्थापना रद्द कर दी है, हालांकि मूल bower.json फ़ाइल में सभी 1.2 को फिर से जोड़ने पर 'devDependencies' के तहत कोणीय-मोक्स और कोणीय-परिदृश्य था। 0-rc.2 घटक कोणीय-मोक्स और कोणीय-परिदृश्य पर निर्भरता के बजाय भटकाव के कारण।

मैं इस बात के लिए उत्सुक हूं कि भक्ति पर निर्भरता का उपयोग कैसे किया जाता है और अगर मुझे मैन्युअल रूप से इसे ठीक करने में परेशान करना चाहिए या जैसा है वैसे ही छोड़ देना चाहिए। क्या बोवर सीएलआई पर निर्दिष्ट करने का एक तरीका है कि किसी चीज को देव निर्भरता के रूप में कैसे चिह्नित किया जाए?

फ़ाइल संपादित करने के बाद:

{
    name: "Angular",
    version: "0.0.0",
    dependencies: {
        json3: "~3.2.4",
        jquery: "~1.9.1",
        bootstrap-sass: "~2.3.1",
        es5-shim: "~2.0.8",
        angular-mocks: "1.2.0-rc.2",
        angular-sanitize: "1.2.0-rc.2",
        angular-resource: "1.2.0-rc.2",
        angular-cookies: "1.2.0-rc.2",
        angular: "1.2.0-rc.2",
        angular-scenario: "1.2.0-rc.2"
    },
    devDependencies: { }
}

संपादन से पहले:

{
    "name": "Angular",
    "version": "0.0.0",
    "dependencies": {
        "angular": "~1.0.7",
        "json3": "~3.2.4",
        "jquery": "~1.9.1",
        "bootstrap-sass": "~2.3.1",
        "es5-shim": "~2.0.8",
        "angular-resource": "~1.0.7",
        "angular-cookies": "~1.0.7",
        "angular-sanitize": "~1.0.7"
    },
    "devDependencies": {
        "angular-mocks": "~1.0.7",
        "angular-scenario": "~1.0.7"
    }
}

जवाबों:


284

devDependencies विकास से संबंधित लिपियों के लिए हैं, जैसे इकाई परीक्षण, पैकेजिंग स्क्रिप्ट, प्रलेखन पीढ़ी, आदि।

dependencies उत्पादन के उपयोग के लिए आवश्यक हैं, और देव के लिए आवश्यक माना जाता है।

भी शामिल है devDependenciesके भीतर dependencies, तुम्हारे पास है के रूप में, हानिकारक नहीं होंगे; मॉड्यूल स्थापित करने के दौरान अधिक फ़ाइलों (बाइट्स) का उपभोग करेगा - अधिक (अनावश्यक) संसाधनों का उपभोग करना। एक शुद्ध पीओवी से, ये अतिरिक्त बाइट्स हानिकारक हो सकते हैं, बस आपके दृष्टिकोण पर निर्भर करता है।

कुछ प्रकाश डाला करने के लिए, पर देख रहे हैं bower help install, के तहत सूचीबद्ध मॉड्यूल devDependenciesके माध्यम से मॉड्यूल स्थापना के दौरान छोड़ा जा सकता है -pया --production, जैसे:

bower install angular-latest --production

यह एक विकास मंच के अलावा किसी अन्य चीज के लिए एक संस्थापन करने का अनुशंसित तरीका है।

इसके विपरीत, के तहत सूचीबद्ध मॉड्यूल को छोड़ने का कोई तरीका नहीं है dependencies


Bower@1.2.7 के अनुसार ( bower नवीनतम स्रोत देखें ), bower helpपैदावार:

Usage:

    bower <command> [<args>] [<options>]

Commands:

    cache                   Manage bower cache
    help                    Display help information about Bower
    home                    Opens a package homepage into your favorite browser
    info                    Info of a particular package
    init                    Interactively create a bower.json file
    install                 Install a package locally
    link                    Symlink a package folder
    list                    List local packages
    lookup                  Look up a package URL by name
    prune                   Removes local extraneous packages
    register                Register a package
    search                  Search for a package by name
    update                  Update a local package
    uninstall               Remove a local package

Options:

    -f, --force             Makes various commands more forceful
    -j, --json              Output consumable JSON
    -l, --log-level         What level of logs to report
    -o, --offline           Do not hit the network
    -q, --quiet             Only output important information
    -s, --silent            Do not output anything, besides errors
    -V, --verbose           Makes output more verbose
    --allow-root            Allows running commands as root

See 'bower help <command>' for more information on a specific command.

और आगे, bower help installपैदावार ( नवीनतम स्रोत देखें ):

Usage:

    bower install [<options>]
    bower install <endpoint> [<endpoint> ..] [<options>]

Options:

    -F, --force-latest      Force latest version on conflict
    -h, --help              Show this help message
    -p, --production        Do not install project devDependencies
    -S, --save              Save installed packages into the project's bower.json dependencies
    -D, --save-dev          Save installed packages into the project's bower.json devDependencies

    Additionally all global options listed in 'bower help' are available

Description:

    Installs the project dependencies or a specific set of endpoints.
    Endpoints can have multiple forms:
    - <source>
    - <source>#<target>
    - <name>=<source>#<target>

    Where:
    - <source> is a package URL, physical location or registry name
    - <target> is a valid range, commit, branch, etc.
    - <name> is the name it should have locally.

जब आप उन्हें bower.json से हटाते हैं, तो ऑटो को बिना हटाए गए डिपों में आने का एक तरीका है?
फुतुओतड़

1
@ फ़ुट्टूआड, मैंने इसे आज़माया नहीं है bower update( लेकिन हटाए गए पुराने डिप्स के साथ लेटेस्ट वर्जन पाने के लिए) bower prune( इसके बाद एक्सट्रेन्सस लोकल पैकेज डिलीट कर देता है) कर सकता है।
ज़मनेट्स

1
@MichaelTrouw यह संभव नहीं है क्योंकि निर्देशिका संरचना मौलिक है। मैं सुझाव दूंगा कि आप अपनी डेवलपमेंट मशीन (या अन्य स्टेजिंग एनवायरनमेंट) पर किसी अन्य डायरेक्टरी में एक प्रोडक्शन इंस्टालेशन का प्रदर्शन करें, जो कि एफ़टीपी के माध्यम से लक्ष्य पर स्नैपशॉट अपलोड कर रहा है।
zamnuts


1
@ आपके उत्पादन कोड को आपके आधार पर निर्भर नहीं होना चाहिए devDependencies, और इसलिए सामान्य रूप से चलने के दौरान आपके बूटस्ट्रैप कोड, तर्क और न ही आपके आवेदन के किसी अन्य पहलू का हिस्सा नहीं है। केवल अगर आप देव-संबंधित कार्यों (स्क्रिप्ट, परीक्षण सूट आदि का निर्माण) को चलाने का प्रयास करते हैं, तो आपको मॉड्यूल नहीं मिलेगा। यदि आपको अधिक जानकारी की आवश्यकता है, तो कृपया SO पर एक नया प्रश्न पूछें। अंत में, बोवर से दूर जाने पर विचार करें क्योंकि यह बहुत अधिक पदावनत है: github.com/bower/bower/issues/2298
zamnuts
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.